当前位置: 技术问答>java相关
急:为什么我的rollback出现了问题。最多只能送这么多。
来源: 互联网 发布时间:2015-02-28
本文导语: 我写了一个bean,其中在executeQuery及executeUpdate中都使用了: conn=driverManager....; 由于我希望先执行了一系列的查询及更新,但最后根据某个条件判断是否更新。 故我在executeUpdate中使用了conn.setAutoCommit(false), 然后在执行了...
我写了一个bean,其中在executeQuery及executeUpdate中都使用了:
conn=driverManager....;
由于我希望先执行了一系列的查询及更新,但最后根据某个条件判断是否更新。
故我在executeUpdate中使用了conn.setAutoCommit(false),
然后在执行了包含executeQuery的函数后,得到conn,并也使用了conn.setAutoCommit(false);
最后重新setAutoCommit(true);
但如果这样的话,多运行几遍会产生Oracle的错误。
为什么?其中,我每次执行时的conn不同,其getAutoCommit()的值是不是也不同?
conn=driverManager....;
由于我希望先执行了一系列的查询及更新,但最后根据某个条件判断是否更新。
故我在executeUpdate中使用了conn.setAutoCommit(false),
然后在执行了包含executeQuery的函数后,得到conn,并也使用了conn.setAutoCommit(false);
最后重新setAutoCommit(true);
但如果这样的话,多运行几遍会产生Oracle的错误。
为什么?其中,我每次执行时的conn不同,其getAutoCommit()的值是不是也不同?
|
rollback使用在一系列更新操作必须一起完成执行(只要有一条失败,就全都要失败)的情况下
例如:
try{
//do update1
//do update2
//do update3
//....
conn.commit();
}
catch(SQLException e){
conn.rollback();
}
所以,你应该用内存纪录要更新的数据,判断完了,在执行数据库操作。总之,应该在同一段代码中完成。(虽然可以传递连接,但很不安全)
例如:
try{
//do update1
//do update2
//do update3
//....
conn.commit();
}
catch(SQLException e){
conn.rollback();
}
所以,你应该用内存纪录要更新的数据,判断完了,在执行数据库操作。总之,应该在同一段代码中完成。(虽然可以传递连接,但很不安全)
您可能感兴趣的文章:
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。