conn.commit(); 的奇怪问题

中国资深步行专家 2008-10-23 03:58:45
Connection conn = null;
conn = DBUtil.getConnect();
if (conn.getAutoCommit()) {
conn.setAutoCommit(false);
}
// 中间可能有多次update,但也有可能一次都没有
........
conn.commit();

如果发生了update conn.commit();正常提交
如果一次都没哟 则,conn.commit();抛出异常异常 "commit() should not be called while in auto-commit mode."
如何解决这个问题。
...全文
1456 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
ynyzp 2009-03-24
  • 打赏
  • 举报
回复
学习
mary_long 2008-11-07
  • 打赏
  • 举报
回复
加一个 try
catch 就行了,即使抛出异常异常 "commit() should not be called while in auto-commit mode." ,不做理会就完了。

--------------------------------------------------------------
几十元把女朋友打扮成清纯公主

  • 打赏
  • 举报
回复
你这个是什么道理呢?


[Quote=引用 6 楼 ruoye_2008 的回复:]
引用 1 楼 looyo 的回复:
conn.commit(); 的时候,以上两种情况下conn.getAutoCommit()==false


Connection conn = null;
conn = DBUtil.getConnect();
conn.setAutoCommit(false);
if (conn.getAutoCommit()) {
conn.setAutoCommit(false);
}
就是加上了第三行,你再试试。
[/Quote]
ruoye_2008 2008-11-03
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 looyo 的回复:]
conn.commit(); 的时候,以上两种情况下conn.getAutoCommit()==false
[/Quote]

Connection conn = null;
conn = DBUtil.getConnect();
conn.setAutoCommit(false);
if (conn.getAutoCommit()) {
conn.setAutoCommit(false);
}
就是加上了第三行,你再试试。
wj63558595 2008-11-03
  • 打赏
  • 举报
回复
建议楼主处理事务的话
用Transaction实现!
一洽客服系统 2008-10-23
  • 打赏
  • 举报
回复
update一条废语句方法不错,如果你能判断是否执行过update操作那样更好
bobolnear 2008-10-23
  • 打赏
  • 举报
回复
你就默认加一个无效的updata语句就可以了。恒等式
dracularking 2008-10-23
  • 打赏
  • 举报
回复
解决方案
1.找jdk源码进commit调试
2.固定加两句update,综合效果为不加
...
  • 打赏
  • 举报
回复
conn.commit(); 的时候,以上两种情况下conn.getAutoCommit()==false

67,516

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧