繁体   English   中英

Java事务-在conn上提交

[英]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不提交事务?

  1. 您尚未向我们显示SQL语句,因此很难说。 也许您的条件很奇怪,所以数据库无法更新/插入/删除任何记录?

  2. 检查executeUpade()结果。 如果更改了任何记录,它应该给您1个或更多

  3. 也许数据库上有TRIGGER阻止了这种操作。 是否可以使用带有硬编码值的updateString从某些SQL编辑器中更改数据库?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM