con.setAutoCommit(false):关闭con事务自动提交功能,必须在sql执行完commit或rollback。
con.setAutoCommit(true):开始con事务自动提交功能,默认开启,sql执行即可提交,
在服务器迁移过程中会遇到java.sql.SQLException: Could not commit with auto-commit set on报错“
原因:早期的ojdbc版本不严格,执行sql,默认自动提交后,继续执行con.commit()没有问题,ojdbc6以后的更高版本,校验更为严格,当自动提交的默认状态未更改继续commit或rollback,就会报此异常。
解决:
1,使用低版本的ojdbc,ojdbc6以下。
2,配置以下jvm启动参数覆盖ojdbc高版本的属性
-Doracle.jdbc.autoCommitSpecCompliant=false
wildfly服务器是在其启动脚本中添加:
...
export JAVA_OPTS="$JAVA_OPTS -Doracle.jdbc.autoCommitSpecCompliant=false"
...
3,在代码中设置con.setAutoCommit(false):

本文探讨了在使用ojdbc6及以上版本时遇到的java.sql.SQLException:Couldnotcommitwithauto-commitseton异常,并提供了三种解决方案:使用低版本ojdbc、配置JVM启动参数或在代码中设置con.setAutoCommit(false)。
3293

被折叠的 条评论
为什么被折叠?



