java 记录sql_通过SQL更新单个记录并获取已更新记录的ID的最佳方法是什么?(Java / MSSQL)...

我知道我可以像这样更新一条记录-但是如何获取已更新记录的ID?(我正在使用MSSQL,所以不能使用Oracle的RowId)

update myTable

set myCol = 'foo'

where itemId in (select top 1 itemId from myTable )

如果我要执行插入操作,则可以使用getGeneratedKeys来获取id字段值,但是我不认为有等效的更新吗?

我知道我可以使用可滚动的结果集来做我想做的事

stmt = conn.prepareStatement("select top 1 myCol, itemId from myTable", ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);

ResultSet resultSet = stmt.executeQuery();

if(resultSet.first()){

resultSet.updateString(1, "foo");

resultSet.updateRow();

String theItemId = resultSet.getString(1)

}

resultSet.close();

但是我担心性能,因为测试显示负载下的锁定超时,我想知道是否有更好/更简单的方法?

-编辑:为了最终解决这个问题…当我们迁移到MSSQL2005时,我们将升级代码以使用Rich的答案。在当前版本中,我们使用了锁定提示:(UPDLOCK ROWLOCK READPAST)来减轻原始代码显示的性能问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值