jfinal Sybase数据源执行create table,alter table报错
@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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
去掉事务单独执行是可以的,我是想在事务里面同时执行一批create/alter语句,有没有什么方法可以实现?
回复
这个应该是 jdbc或者数据库不支持,在 jfinal 层面只能尝试 DbKit.getConfig().getConnection() 拿到Connection对象,或者通过 getDataSource() 拿到 dataSource对象,或者通过改变数据库的配置来实现
回复
jfinal 未对此进行过任何干预,所以只能是从jdbc或数据库层面尝试解决
回复
好的,我自己再研究一下,谢谢啦~
错误提示已经很明确了:无法在 "TEST" 数据库的多语句事务中执行 "ALTER TABLE" 命令,去掉事务试试