[英]Java transaction - commit on conn doesn't
假设我有以下Java代码片段(在旧版应用中嵌入了类似的代码)
...
try {
con.setAutoCommit(false);
updateSales = con.prepareStatement(updateString);
updateTotal = con.prepareStatement(updateStatement);
updateSales.setInt(1, e.getValue().intValue());
updateSales.setString(2, e.getKey());
updateSales.executeUpdate();
updateTotal.setInt(1, e.getValue().intValue());
updateTotal.setString(2, e.getKey());
updateTotal.executeUpdate();
con.commit();
} catch (SQLException e ) {
...
假设这已连接到SQL Server 2005数据库(使用ms 2005驱动程序)-是否有任何理由使con.commit不提交事务?
您尚未向我们显示SQL语句,因此很难说。 也许您的条件很奇怪,所以数据库无法更新/插入/删除任何记录?
检查executeUpade()
结果。 如果更改了任何记录,它应该给您1个或更多
也许数据库上有TRIGGER阻止了这种操作。 是否可以使用带有硬编码值的updateString
从某些SQL编辑器中更改数据库?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.