Spring使用JdbcTemplate操作数据库---使用RowCallbackHander读数据篇

首先,假设如下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 >

< 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();
}

}

 

DAO:

其中getPersonByRowCallbackHandler方法根据username获得person对象

package  SpringJDBCSupport.ReadData;

import  java.sql.PreparedStatement;
import  java.sql.ResultSet;
import  java.sql.SQLException;
import  java.sql.Types;
import  java.util.List;

import  org.springframework.jdbc.core.BatchPreparedStatementSetter;
import  org.springframework.jdbc.core.JdbcTemplate;
import  org.springframework.jdbc.core.RowCallbackHandler;

public   class  PersonDAO  {
  
private JdbcTemplate jdbcTemplate;

public JdbcTemplate getJdbcTemplate() {
    
return jdbcTemplate;
}


public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
    
this.jdbcTemplate = jdbcTemplate;
}


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);
}


public Person getPersonByRowCallbackHandler(String username){

    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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JdbcTemplateSpring框架提供的一个用于简化数据库操作的工具类。它封装了JDBC的细节,提供了一组简洁的API来执行SQL语句并处理结果集。下面是使用JdbcTemplate进行数据库操作的基本步骤: 1. 配置数据源:在Spring配置文件中配置数据源,例如使用`org.springframework.jdbc.datasource.DriverManagerDataSource`类配置一个基于驱动程序管理的数据源。 2. 创建JdbcTemplate对象:在Spring配置文件中创建一个`org.springframework.jdbc.core.JdbcTemplate`对象,并将数据源注入到该对象中。 3. 编写SQL语句:根据需求编写SQL语句,可以使用占位符来代替参数。 4. 执行SQL语句:使用JdbcTemplate对象的方法执行SQL语句,例如`update()`方法用于执行INSERT、UPDATE和DELETE语句,`query()`方法用于执行SELECT语句。 5. 处理结果集:根据需要处理查询结果集,可以使用`RowMapper`接口来映射每一行的数据到Java对象。 下面是一个简单的示例代码: ```java import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.RowMapper; public class UserDao { private JdbcTemplate jdbcTemplate; public void setJdbcTemplate(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } public void addUser(User user) { String sql = "INSERT INTO user (id, name, age) VALUES (?, ?, ?)"; jdbcTemplate.update(sql, user.getId(), user.getName(), user.getAge()); } public User getUserById(int id) { String sql = "SELECT * FROM user WHERE id = ?"; RowMapper<User> rowMapper = new UserRowMapper(); return jdbcTemplate.queryForObject(sql, rowMapper, id); } } class User { private int id; private String name; private int age; // 省略getter和setter方法 } class UserRowMapper implements RowMapper<User> { @Override public User mapRow(ResultSet rs, int rowNum) throws SQLException { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setAge(rs.getInt("age")); return user; } } ``` 以上代码演示了如何使用JdbcTemplate进行数据库操作,包括插入数据和查询数据。你可以根据具体的需求进行扩展和修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值