这2天学习了atomikos事务控制框架,其中看到有3种数据源,分别是,SimpleDataSourceBean,AtomikosDataSourceBean,AtomikosNonXADataSourceBean。

在看atomikos文档的时候,一直有个疑点,就是文档好像强调要用xadatasource,用nonxadatasource好像就不支持事务了。

但是这3个数据源有2个是xadatasource,另一个是nonxadatasource。那看起来就矛盾了。于是实验了一下,用AtomikosNonXADataSourceBean做数据源,

同时操作2个数据源,在后一个数据源操作中故意抛出异常。结果数据都没有保存进数据库。

后台也显示rollback成功了。

所以nonxadatasource也可以用。

百度百科里说,

连接

XA连接区别于非XA连接。要记住的是XA连接是一个JTA事务中的参与者。这就意味着XA连接不支持JDBC的自动提交特性。也就是说应用程序不必在XA连接上调用java.sql.Connection.commit()或java.sql.Connection.rollback()。相反,应用程序应该使用UserTransaction.begin()、UserTransaction.commit()和UserTransaction.rollback().
区别可能就在这了,如果用xadatasource就可以用UserTransaction.begin()这些操作,
如果用nonxadatasource,就不支持这些操作了。
这只是猜想,具体待验证。

相关文章:

  • 2021-12-24
  • 2021-06-04
  • 2022-12-23
  • 2021-06-09
  • 2022-12-23
  • 2022-12-23
  • 2021-07-29
  • 2021-12-29
猜你喜欢
  • 2022-02-24
  • 2022-12-23
  • 2021-05-04
  • 2021-09-07
相关资源
相似解决方案