欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Spring使用JdbcTemplate操作數據庫---使用RowMa

系統 1658 0

首先建立數據表:

CREATE TABLE `login` (
? `username` varchar(10) default NULL,
? `passwd` varchar(10) default NULL,
? `address` varchar(10) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=gb2312;

?

配置文件:

?

<? xml?version="1.0"?encoding="UTF-8" ?>
<! DOCTYPE?beans?PUBLIC?"-//SPRING//DTD?BEAN//EN"?"http://www.springframework.org/dtd/spring-beans.dtd"? >
< beans >
?
< bean? id ="dataSource" ?class ="org.apache.commons.dbcp.BasicDataSource" >
???
< property? name ="driverClassName" >
?????
< value > com.mysql.jdbc.Driver </ value >
???
</ property >
???
< property? name ="url" >
?????
< value > jdbc:mysql://localhost:3306/javaee </ value >
???
</ property >
???
< property? name ="username" >
?????
< value > root </ value >
???
</ property >
???
< property? name ="password" >
?????
< value > 1234 </ value >
???
</ property >
?
</ bean >
?
< bean? id ="jdbcTemplate" ?class ="org.springframework.jdbc.core.JdbcTemplate" >
???
< property? name ="dataSource" >
?????
< ref? local ="dataSource" />
???
</ property >
?
</ bean >

< bean? id ="personDAO" ?class ="SpringJDBCSupport.ReadData.PersonDAO" >
??
< property? name ="jdbcTemplate" >
????
< ref? local ="jdbcTemplate" />
??
</ property >
</ bean > ?
</ beans >

?JavaBean

?

package ?SpringJDBCSupport.ReadData;
import ?com.mysql.jdbc.Driver;
public ? class ?Person? ... {
??
private ?String?name;
??
private ?String?password;
??
private ?String?address;
??
public ?Person() ... {
??????
??}

??
public ?Person(String?name,String?password,String?address) ... {
??????
this .name = name;
??????
this .password = password;
??????
this .address = address;
??}

public ?String?getAddress()? ... {
????
return ?address;
}

public ? void ?setAddress(String?address)? ... {
????
this .address? = ?address;
}

public ?String?getName()? ... {
????
return ?name;
}

public ? void ?setName(String?name)? ... {
????
this .name? = ?name;
}

public ?String?getPassword()? ... {
????
return ?password;
}

public ? void ?setPassword(String?password)? ... {
????
this .password? = ?password;
}

public ?String?toString() ... {
????
return ? this .getName() + " - " + this .getPassword() + " - " + this .getAddress();
}

}

?

編寫自定義RowMapper

?

package ?SpringJDBCSupport.ReadData;

import ?java.sql.ResultSet;
import ?java.sql.SQLException;

import ?org.springframework.jdbc.core.RowMapper;

public ? class ?PersonRowMapper? implements ?RowMapper? ... {

????
public ?Object?mapRow(ResultSet?rs,? int ?index)? throws ?SQLException? ... {
????????Person?person
= new ?Person();
????????person.setName(rs.getString(
" username " ));
????????person.setPassword(rs.getString(
" passwd " ));
????????person.setAddress(rs.getString(
" address " ));
????????
return ?person;
????}


}

?

測試代碼:

?

package ?SpringJDBCSupport.ReadData;

import ?java.io.File;
import ?java.util.ArrayList;
import ?java.util.Iterator;
import ?java.util.List;

import ?org.springframework.beans.factory.BeanFactory;
import ?org.springframework.beans.factory.xml.XmlBeanFactory;
import ?org.springframework.core.io.FileSystemResource;

public ? class ?TestJDBCTemplate? ... {

????
public ? static ?String?filePath = "" ;
????
public ? static ?BeanFactory?factory = null ;
????
public ? static ? void ?main(String[]?args)? ... {
????????filePath
= System.getProperty( " user.dir " ) + File.separator + " SpringJDBCSupport " + File.separator + " ReadData " + File.separator + " hello.xml " ;
????????factory
= new ?XmlBeanFactory( new ?FileSystemResource(filePath));
????????PersonDAO?personDAO
= (PersonDAO)factory.getBean( " personDAO " );
????????
/**/ /*
?????????*?準備數據
?????????
*/

????????Person?p1
= new ?Person( " test1 " , " test1 " , " test1 " );
????????Person?p2
= new ?Person( " test2 " , " test2 " , " test2 " );
????????Person?p3
= new ?Person( " test3 " , " test3 " , " test3 " );
????????Person?p4
= new ?Person( " test4 " , " test4 " , " test4 " );
????????Person?p5
= new ?Person( " test5 " , " test5 " , " test5 " );
????????List?persons
= new ?ArrayList();
????????persons.add(p3);
????????persons.add(p4);
????????persons.add(p5);
????????
// 使用jdbcTemplate.update方式
????????personDAO.insertPersonUseUpdate(p1);
????????
// 使用jdbcTemplate.execute方式
????????personDAO.insertPersonUseExecute(p2);
????
// ???? // 使用jdbcTemplate批處理方式
????????personDAO.updatePersonUseBatchUpdate(persons);
????????
????????
// 使用RowCallbackHandler執行一次查詢,并打印person信息
????????System.out.println(personDAO.getPersonByRowCallbackHandler( " test1 " ));
????????List?a
= personDAO.getPersonsByMapperResultReader();
????????
for ?(Iterator?iter? = ?a.iterator();?iter.hasNext();)? ... {
????????????System.out.println((Person)iter.next());
????????????
????????}

????}

????
????

}

?

運行程序:輸出為以下結果,紅色部分為查詢結果集

test1-test1-test1
test1-test1-test1
test2-test2-test2
test3-test3-test3
test4-test4-test4
test5-test5-test5

我們完全可以用這個方法代替RowCallbackHandler,用一個自定義的RowMapper結局單個查詢和結果集查詢兩種方式,返回單個對象是,只要修改

List result=(ArrayList)this.getJdbcTemplate().query(sql,params,new RowMapperResultSetExtractor(new PersonRowMapper()));
return result.get(0);
}

即可



Spring使用JdbcTemplate操作數據庫---使用RowMapperResultSetExtractor讀數據篇


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 免费国产成人高清视频网站 | 欧美亚洲视频一区 | 奇米影视亚洲精品一区 | 国产亚洲欧美视频 | 毛片免费观看 | 男人电影天堂 | 夜夜撸.com| 欧美精品一区二区在线观看 | 人人看人人搞 | 午夜丁香 | 亚洲国产一区二区三区四区色欲 | 国产精品美女久久久久aⅴ国产馆 | 香蕉视频免费网站 | 色网站在线免费观看 | 久久久国产精品免费观看 | 亚洲成年人免费网站 | 日本高清香蕉色视频在线观看 | 午夜家庭影院 | 日本夜夜操 | 色综合久久婷婷天天 | 一级毛片,一级毛片 | 999精品嫩草久久久久久99 | 精品欧美在线观看 | 日本一级淫片1000部 | 色婷婷综合久久久久中文 | 久草网站在线 | 久久综合九色综合欧洲色 | 欧美日韩综合视频 | 久久www免费人成看片色多多 | 黄视频网站免费观看 | 魔法骑士在线观看免费完整版 | 一级免费黄色免费片 | 国产在线精彩视频 | 国产福利区一区二在线观看 | 久久亚洲在线 | 日本毛片免费看 | 欧美1区2区| 国产精品无码人妻系列AV | 天天天天做夜夜夜夜 | 日本黄页网站免费 | 人人狠狠综合久久亚洲 |