日期:2014-05-16  浏览次数:20501 次

jdbctemplate_的使用
1、表的操作

使用JdbcTemplate的execute()方法执行SQL语句
    execute方法总是使用 java.sql.Statement,不接受参数,而且他不返回受影响记录的计数,更适合于创建和丢弃表的语句。
jdbcTemplate.execute("CREATE TABLE USER (user_id integer, name varchar(100))");  

2、增、删和改

update方法update方法返回的是受影响的记录数目的一个计数,并且如果传入参数的话,使用的是java.sql.PreparedStatement,更适合于插入,更新和删除操作

1)不带参数的更新
jdbcTemplate.update("INSERT INTO USER VALUES('"  
           + user.getId() + "', '"  
           + user.getName() + "', '"  
           + user.getSex() + "', '"  
           + user.getAge() + "')");


2)带参数的更新
jdbcTemplate.update("UPDATE USER SET name = ? WHERE user_id = ?", new Object[]            {name, id});  
代码:jdbcTemplate.update("INSERT INTO USER VALUES(?, ?, ?, ?)", new Object[] {user.g   etId(), user.getName(), user.getSex(), user.getAge()}); 
 

3)JDBC的PreparedStatement
------单个更新
final String id = user.getId();   
final String name = user.getName();   
final String sex = user.getSex() + "";   
final int age = user.getAge();   
  
jdbcTemplate.update("INSERT INTO USER VALUES(?, ?, ?, ?)",   
                     new PreparedStatementSetter() {   
                         public void setValues(PreparedStatement ps) throws SQLException {   
                             ps.setString(1, id); //需要注意: 匿名内部类 只能访问外部最终局部变量
                             ps.setString(2, name);             
                             ps.setString(3, sex);   
                             ps.setInt(4, age);   
                         }   
                     }); 
 

------批量更新
需要批处理,可以实现org.springframework.jdbc.core.BatchPrepared- StatementSetter接口:
package org.springframework.jdbc.core;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public interface BatchPreparedStatementSetter {
    void setValues(PreparedStatement ps,
                      int i) throws SQLException;
    int getBatchSize();
}
 
...
public int[] insertUsers(final List users) {
    String sql = "INSERT INTO user (name,age) VALUES(?,?)";
    BatchPreparedStatementSetter setter =
      new BatchPreparedStatementSetter() {
        public void setValues(
            PreparedStatement ps, int i) throws SQLException {
            User user = (User) users.get(i);
            ps.setString(1, user.getName());
            ps.setInt(2, user.getAge().intValue());
        }
        public int getBatchSize() {
            return users.size();
        }
      };
    return jdbcTemplate.batchUpdate(sql, setter);
}

...
如果JDBC驱动程序支持批处理,则直接使用它的功能,如果不支持, Spring则会一个一个自动处理更新以模拟批处理。
3、查询

1)使用JdbcTemplate进行查询时,使用queryForXXX()等方法
?         Queries, using convenience methods
代码:
int count = jdbcTemplate.queryForInt("SELECT COUNT(*) FROM 
USER"); 
代码:
String name = (String) jdbcTemplate.queryForObject("SELECT name FROM USER WHERE user_id = ?", new Object[] {id}, java.lang.String.class); 

代码:
List rows = jdbcTemplate.queryForList("SELECT * FROM USER");  
Returns an ArrayList (one entry for each row) of HashMaps (one entry for each column using the column name as the key)


代码:
List rows = jdbcTemplate.queryForList("SELECT * FROM USER");   
Iterator it = rows.iterator();   
while(it.hasNext()) {   
    Map userMap = (Map) it.next();   
    System.out.print(userMap.get("user_id") + "\t");   
    System.out.print(userMap.get("name") + "\t");   
    System.out.print(userMap.get("sex") + "\t");   
    System.out.println(userMap.get("age") + "\t");   
} 


2)JDBC的callback方式
?