jfinal Sybase数据源执行create table,alter table报错

发布于 2021-11-30 23:16:20 字数 825 浏览 993 评论 5

@JFinal 你好,想跟你请教个问题:Jfinal执行事务在Sybase create/alter语句出错:
com.jfinal.plugin.activerecord.ActiveRecordException: com.sybase.jdbc3.jdbc.SybSQLException: The 'ALTER TABLE' command is not allowed within a multi-statement transaction in the 'TEST' database.


at com.jfinal.plugin.activerecord.DbPro.update(DbPro.java:279)
at com.jfinal.plugin.activerecord.DbPro.update(DbPro.java:290)
at com.suntek.iccmgr.cust.util.TransactionUtil$2.run(TransactionUtil.java:63)
at com.jfinal.plugin.activerecord.DbPro.tx(DbPro.java:644)
at com.jfinal.plugin.activerecord.DbPro.tx(DbPro.java:680)

但是数据源是Oracle的话是可以执行成功的,请问是什么问题导致的呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

眼泪淡了忧伤 2021-12-01 19:41:20

去掉事务单独执行是可以的,我是想在事务里面同时执行一批create/alter语句,有没有什么方法可以实现?

你曾走过我的故事 2021-12-01 17:49:20

回复
这个应该是 jdbc或者数据库不支持,在 jfinal 层面只能尝试 DbKit.getConfig().getConnection() 拿到Connection对象,或者通过 getDataSource() 拿到 dataSource对象,或者通过改变数据库的配置来实现

噩梦成真你也成魔 2021-12-01 16:54:10

回复
jfinal 未对此进行过任何干预,所以只能是从jdbc或数据库层面尝试解决

执手闯天涯 2021-12-01 09:49:30

回复
好的,我自己再研究一下,谢谢啦~

谁的新欢旧爱 2021-12-01 09:37:26

错误提示已经很明确了:无法在 "TEST" 数据库的多语句事务中执行 "ALTER TABLE" 命令,去掉事务试试

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文