使用JdbcTemplate取得插入Oracle记录的主键值



使用JdbcTemplate取得插入Oracle记录的主键值

使用JdbcTemplate取得插入Oracle记录的主键值 在使用spring的过程中经常遇到获取插入数据的主键值,在使用jdbc时我们可能已经会使用了,但是在spring的jdbcTemplate中也有相关的方法:

第一种方法:

public int getKey1(User user){

int i = 0;

final String name = user.getUserName();

final String password = user.getPassword();

final int age = user.getAge();

KeyHolder keyHolder = new GeneratedKeyHolder();

final String sql = "insert into tb_user(user_name,password,age) values(?,?,?)";

jdbcTemplate.update(new PreparedStatementCreator(){



public PreparedStatement createPreparedStatement(Connection conn)

throws SQLException {

PreparedStatement ps = conn.prepareStatement(sql,new String[]{"user_id"});

ps.setString(1, name);

ps.setString(2, password);

ps.setInt(3, age);

return ps;

}

}, keyHolder);

i = keyHolder.getKey().intValue();

return i;

}



第二种方法:


public int getKey2(User user){

//这里withTableName("tb_user")面是 表名,usingGeneratedKeyColumns("user_id")表字段主键

SimpleJdbcInsert insertActor =  new SimpleJdbcInsert(jdbcTemplate.getDataSource()).withTableName("tb_user").usingGeneratedKeyColumns("user_id");

Map<String, Object> parameters = new HashMap<String, Object>(); 

        parameters.put("user_name", user.getUserName());

        parameters.put("password", user.getPassword());

        parameters.put("age", user.getAge());

        Number newId = insertActor.executeAndReturnKey(parameters);

return newId.intValue();

}



Java代码 复制代码  收藏代码
  1. import java.sql.Connection;  
  2. import java.sql.PreparedStatement;  
  3. import java.sql.SQLException;  
  4. import java.text.ParseException;  
  5.   
  6. import org.springframework.jdbc.core.PreparedStatementCreator;  
  7. import org.springframework.jdbc.support.GeneratedKeyHolder;  
  8. import org.springframework.jdbc.support.KeyHolder;  
  9.   
  10. import com.kjlink.cms.form.model.LabelForm;  
  11. import com.kjlink.cms.service.BaseService;  
  12.   
  13. public class ff extends BaseService {  
  14.   
  15. public int insertTable(LabelForm f) throws SQLException,ParseException   
  16. {  
  17. String content = f.getSiteId();  
  18. final String sql = "insert into TAG_INFO(SITE_ID,NAME,CONTENT) values(?,?,'"+content+"')";  
  19. KeyHolder keyHolder = new GeneratedKeyHolder();  
  20. getJdbcTemplate().update(  
  21.    new PreparedStatementCreator() {  
  22.     public PreparedStatement createPreparedStatement(Connection con) throws SQLException   
  23.     {  
  24.      PreparedStatement ps = getJdbcTemplate().getDataSource()  
  25.        .getConnection().prepareStatement(sql,new String[]{ "SITE_ID" ,"NAME"});  
  26.      ps.setString(1"站点号");  
  27.      ps.setString(2"我的名字");  
  28.      return ps;  
  29.     }  
  30.    }, keyHolder);  
  31.    System.out.println("自动插入id============================" + keyHolder.getKey().intValue());  
  32.    return keyHolder.getKey().intValue();  
  33. }  
  34. }  






评论


1 楼 pch272215690 2013-06-18  
我比较喜欢用第三种方法:
Java代码 复制代码  收藏代码
  1. GeneratedKeyHolder generatedKeyHolder = new GeneratedKeyHolder();  
  2.         SqlParameterSource paramSource = new BeanPropertySqlParameterSource(employe);  
  3.           
  4.         final String sql =  "INSERT INTO `employe` (`emp_name`, `sex`, `age`,`remark`) VALUES (:name, :sex, :age, :remark)";  
  5.           
  6.         namedParameterJdbcTemplate.update(sql, paramSource, generatedKeyHolder,new String[]{"id_"});  
  7.           
  8.         Number number = generatedKeyHolder.getKey();  
  9.           
  10.         return number.longValue();  
GeneratedKeyHolder generatedKeyHolder = new GeneratedKeyHolder();
        SqlParameterSource paramSource = new BeanPropertySqlParameterSource(employe);
        
        final String sql =  "INSERT INTO `employe` (`emp_name`, `sex`, `age`,`remark`) VALUES (:name, :sex, :age, :remark)";
        
        namedParameterJdbcTemplate.update(sql, paramSource, generatedKeyHolder,new String[]{"id_"});
        
        Number number = generatedKeyHolder.getKey();
        
        return number.longValue();


spring的版本是3.1.1,不知道老版本的namedParameterJdbcTemplate支持不。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值