利用JDBC获取新插入记录id的三种方法
来源:互联网 发布:淘宝手帐本推荐店铺 编辑:程序博客网 时间:2024/06/04 19:40
在一对多的关联操作中,通常在一方插入记录后,需要获取到当前记录的id,以方便进行多方的插入操作。要解决这一问题,在JDBC中至少有三种不同的实现方法:
1.在插入语句后添加一条查询,利用resultset来得到id号
psmt = con.prepareStatement
("insert into orders (receiver,address,telephone,total,detailnum,userid)values(?,?,?,?,?,?);select
@@identity");
psmt.setString(1, order.getReceiver());
……
results = psmt.executeQuery();
if(results.next())
{
num = results.getInt(1);
}
2.利用generatedKey来获取id
psmt = con.prepareStatement
("insert into orders (receiver,address,telephone,total,detailnum,userid)values
(?,?,?,?,?,?)",Statement.RETURN_GENERATED_KEYS);
psmt.setString(1, order.getReceiver());
……
psmt.executeUpdate();
results = psmt.getGeneratedKeys();
int num = -1;
if(results.next())
{
num = results.getInt(1);
}
3.调用存储过程来实现,当然这种情况下,插入对象的属性不宜过多,否则存储过程的输入参数太多。在存储过程中,将id作为输出参数返回
CallableStatement proc = conn.prepareCall("{call proc_insert(?,?,?)}");
proc.setString(1, cardname);
proc.setInt(2, money);
proc.registerOutParameter(3, Types.INTEGER);
proc.execute();
num = proc.getInt(3)
- JDBC获取新插入记录id的三种方法
- 利用JDBC获取新插入记录id的三种方法
- 利用JDBC获取新插入记录id的三种方法
- 获取新插入的记录ID
- Mysql中获取新插入的自增id的三种方法
- Mysql,access,mssql server三种数据库获得新插入记录id的方法
- SQLserver 获取数据表新插入记录ID方法---SCOPE_IDENTITY与@@INDENTITY的区别
- MySQL使用LAST_INSERT_ID()获取新插入记录的ID
- 插入一条记录后,马上得到新插入记录ID值的方法。good
- 插入一条记录后,马上得到新插入记录ID值的方法
- Java获取最后插入MySQL记录的自增ID值的3种方法
- Mysql中获取刚插入的自增长id的三种方法归纳
- Mysql中获取刚插入的自增长id的三种方法归纳
- Mysql中获取刚插入的自增长id的三种方法归纳
- Mysql中获取刚插入的自增id的三种方法
- Mysql中获取刚插入的自增长id的三种方法归纳
- Mysql中获取刚插入的自增长id的三种方法归纳
- 获取新插入数据的ID
- SQLITE3 使用总结
- mysql中查询前10条记录
- Jqury 中超链接的设置
- 让FireFox支持InnerText属性
- MySQL性能优化---explain
- 利用JDBC获取新插入记录id的三种方法
- error C2236: unexpected 'class' 'CExplosionData'. Did you forget a ';'?
- Ogre源码分析之Root类、Facade模式
- winform 中添加text和value值
- mybatis 之 环境搭建
- Android类动态加载技术
- 表格 CSS(不换行) HTML <td> 标签的 nowrap 属性
- 静态SQL和动态SQL
- Project Euler problem 33