首先,假设如下SQL表中有数据username=test1,passwd=test1,address=test1
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
>
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
<
bean
id
="personDAO"
class
="SpringJDBCSupport.ReadData.PersonDAO"
>
<
property
name
="jdbcTemplate"
>
<
ref
local
="jdbcTemplate"
/>
</
property
>
</
bean
>
</
beans
>
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
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();
}
}
DAO:
其中getPersonByRowCallbackHandler方法根据username获得person对象
package
SpringJDBCSupport.ReadData;
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
import
java.sql.PreparedStatement;
import
java.sql.ResultSet;
import
java.sql.SQLException;
import
java.sql.Types;
import
java.util.List;
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
import
org.springframework.jdbc.core.BatchPreparedStatementSetter;
import
org.springframework.jdbc.core.JdbcTemplate;
import
org.springframework.jdbc.core.RowCallbackHandler;
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
public
class
PersonDAO
{
private JdbcTemplate jdbcTemplate;
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/InBlock.gif)
public JdbcTemplate getJdbcTemplate() {
return jdbcTemplate;
}
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/InBlock.gif)
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/InBlock.gif)
public int insertPersonUseUpdate(Person person){
String sql="insert into login values(?,?,?)";
Object[] params=new Object[]{
person.getName(),
person.getPassword(),
person.getAddress()
};
return this.getJdbcTemplate().update(sql,params);
}
public int insertPersonUseExecute(Person person){
String sql="insert into login values(?,?,?)";
Object[] params=new Object[]{
person.getName(),
person.getPassword(),
person.getAddress()
};
int[] types=new int[]{
Types.VARCHAR,
Types.VARCHAR,
Types.VARCHAR
};
return this.getJdbcTemplate().update(sql,params,types);
}
public int[] updatePersonUseBatchUpdate( final List persons){
String sql="insert into login values(?,?,?)";
BatchPreparedStatementSetter setter=null;
setter=new BatchPreparedStatementSetter(){
public int getBatchSize(){
return persons.size();
}
public void setValues(PreparedStatement ps,int index) throws SQLException{
Person person=(Person)persons.get(index);
ps.setString(1,person.getName());
ps.setString(2,person.getPassword());
ps.setString(3,person.getAddress());
}
};
return this.getJdbcTemplate().batchUpdate(sql,setter);
}
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/InBlock.gif)
public Person getPersonByRowCallbackHandler(String username){
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/InBlock.gif)
String sql="select * from login where username=?";
final Person person=new Person();
final Object params[]=new Object[]{username};
this.getJdbcTemplate().query(sql,params,new RowCallbackHandler(){
public void processRow(ResultSet rs)throws SQLException{
person.setName(rs.getString("username"));
p