JDBC获取新插入记录id的三种方法
2012-10-24 16:59
585 查看
文章转自网络
在一对多的关联操作中,通常在一方插入记录后,需要获取到当前记录的id,以方便进行多方的插入操作。要解决这一问题,在JDBC中至少有三种不同的实现方法:
1.在插入语句后添加一条查询,利用resultset来得到id号
psmt = con.prepareStatement ("insert
into orders
(receiver,address,telephone,total,detailnum,userid)values(?,?,?,?,?,?)");
psmt.setString(1,
order.getReceiver());
……
psmt.executeUpdate();
psmt = con.prepareStatement ("select @@identity");
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(?,?,?,?,?,?)");
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();
int num = proc.getInt(3)
在一对多的关联操作中,通常在一方插入记录后,需要获取到当前记录的id,以方便进行多方的插入操作。要解决这一问题,在JDBC中至少有三种不同的实现方法:
1.在插入语句后添加一条查询,利用resultset来得到id号
psmt = con.prepareStatement ("insert
into orders
(receiver,address,telephone,total,detailnum,userid)values(?,?,?,?,?,?)");
psmt.setString(1,
order.getReceiver());
……
psmt.executeUpdate();
psmt = con.prepareStatement ("select @@identity");
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(?,?,?,?,?,?)");
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();
int num = proc.getInt(3)
相关文章推荐
- JDBC获取新插入记录id的三种方法
- 利用JDBC获取新插入记录id的三种方法
- (转)利用JDBC获取新插入记录id的三种方法
- JDBC插入Oracle数据库有主键的X表记录时,获取此记录的主键ID。
- 插入数据后, 获取该记录id的方法
- 如何插入一条记录获取插入后的自动增长ID列的方法.
- 如何插入一条记录获取插入后的自动增长ID列的方法.
- Mysql中获取新插入的自增id的三种方法
- Java获取最后插入MySQL记录的自增ID值的3种方法
- Mysql中获取刚插入的自增id的三种方法
- Mysql中获取刚插入的自增长id的三种方法归纳
- 三种返回mysql 插入一条记录返回该记录id方法
- Mysql中获取刚插入的自增长id的三种方法归纳
- Mysql中获取刚插入的自增长id的三种方法归纳
- Mysql中获取刚插入的自增长id的三种方法归纳
- SQLserver 获取数据表新插入记录ID方法---SCOPE_IDENTITY与@@INDENTITY的区别
- Mysql中获取刚插入的自增长id的三种方法归纳
- Mysql,access,mssql server三种数据库获得新插入记录id的方法
- Java获取最后插入MySQL记录的自增ID值方法
- Mysql中获取刚插入的自增长id的三种方法归纳