场景介绍:

一个项目俩个数据源,连接俩个不同的库

数据源初始化

@Configuration
@MapperScan(basePackages = "com.qing.mapper.payment", sqlSessionTemplateRef = "paymentSqlSessionTemplate")
public class PaymentDataSourceConfig { @Bean(name = "paymentDataSource")
@ConfigurationProperties(prefix = "spring.datasource.payment")
@Primary
public DataSource paymentDataSource() {
return DruidDataSourceBuilder.create().build();
} @Bean(name = "paymentSqlSessionFactory")
@Primary
public SqlSessionFactory paymentSqlSessionFactory(@Qualifier("paymentDataSource") DataSource dataSource) throws Exception {
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(dataSource);
return bean.getObject();
} @Bean(name = "paymentTransactionManager")
@Primary
public DataSourceTransactionManager paymentTransactionManager(@Qualifier("paymentDataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
} @Bean(name = "paymentSqlSessionTemplate")
@Primary
public SqlSessionTemplate paymentSqlSessionTemplate(@Qualifier("paymentSqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
return new SqlSessionTemplate(sqlSessionFactory);
} }
@Configuration
@MapperScan(basePackages = "com.qing.mapper.read", sqlSessionTemplateRef = "readSqlSessionTemplate")
public class ReadDataSourceConfig { @Bean(name = "readDataSource")
@ConfigurationProperties(prefix = "spring.datasource.read")
public DataSource readDataSource() {
return DruidDataSourceBuilder.create().build();
} @Bean(name = "readSqlSessionFactory")
public SqlSessionFactory readSqlSessionFactory(@Qualifier("readDataSource") DataSource dataSource) throws Exception {
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(dataSource);
return bean.getObject();
} @Bean(name = "readTransactionManager")
public DataSourceTransactionManager readTransactionManager(@Qualifier("readDataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
} @Bean(name = "readSqlSessionTemplate")
public SqlSessionTemplate readSqlSessionTemplate(@Qualifier("readSqlSessionFactory") SqlSessionFactory sqlSessionFactory) {
return new SqlSessionTemplate(sqlSessionFactory);
} }

测试代码

@Service
public class TestService
{ @Autowired
VipOrderReadingMapper mapper1; @Autowired
TenVipOrderReadingMapper mapper2; @Autowired
GlobalRefundOrderMapper mapper3; @Transactional
public void test()
{ mapper1.test();
mapper3.test();
mapper2.test();
throw new RuntimeException("test");
} }

执行日志

-- ::04.584 [http-nio--exec-] DEBUG o.s.jdbc.datasource.DataSourceTransactionManager - Acquired Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@3a6cc709] for JDBC transaction
-- ::04.588 [http-nio--exec-] DEBUG o.s.jdbc.datasource.DataSourceTransactionManager - Switching JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@3a6cc709] to manual commit
-- ::04.637 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Creating a new SqlSession
-- ::04.650 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@18b9642b]
-- ::04.657 [http-nio--exec-] DEBUG o.springframework.jdbc.datasource.DataSourceUtils - Fetching JDBC Connection from DataSource
-- ::04.658 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/deny-variant.txt)
-- ::04.658 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/deny-schema.txt)
-- ::04.659 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/deny-function.txt)
-- ::04.659 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/deny-table.txt)
-- ::04.660 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/deny-object.txt)
-- ::04.660 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/readonly-table.txt)
-- ::04.660 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/permit-function.txt)
-- ::04.661 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/permit-table.txt)
-- ::04.662 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/permit-schema.txt)
-- ::04.662 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/druid/wall/mysql/permit-variant.txt)
-- ::04.663 [http-nio--exec-] DEBUG org.apache.catalina.loader.WebappClassLoaderBase - findResources(META-INF/services/com.alibaba.druid.filter.Filter)
-- ::05.868 [http-nio--exec-] INFO com.alibaba.druid.pool.DruidDataSource - {dataSource-} inited
-- ::05.868 [http-nio--exec-] DEBUG o.springframework.jdbc.datasource.DataSourceUtils - Registering transaction synchronization for JDBC Connection
-- ::05.870 [http-nio--exec-] DEBUG o.m.spring.transaction.SpringManagedTransaction - JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@58c237f2] will be managed by Spring
-- ::05.874 [http-nio--exec-] DEBUG c.q.mapper.read.order.VipOrderReadingMapper.test - ==> Preparing: update vip_order_reading set order_status = where reading_vip_order_id =
-- ::06.049 [http-nio--exec-] DEBUG c.q.mapper.read.order.VipOrderReadingMapper.test - ==> Parameters:
-- ::06.191 [http-nio--exec-] DEBUG c.q.mapper.read.order.VipOrderReadingMapper.test - <== Updates:
-- ::06.192 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@18b9642b]
-- ::06.192 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Creating a new SqlSession
-- ::06.192 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Registering transaction synchronization for SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@22fb4694]
-- ::06.194 [http-nio--exec-] DEBUG o.m.spring.transaction.SpringManagedTransaction - JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@3a6cc709] will be managed by Spring
-- ::06.194 [http-nio--exec-] DEBUG c.q.m.payment.order.GlobalRefundOrderMapper.test - ==> Preparing: select count(*) fromglobal_refund_order
-- ::06.198 [http-nio--exec-] DEBUG c.q.m.payment.order.GlobalRefundOrderMapper.test - ==> Parameters:
-- ::06.255 [http-nio--exec-] DEBUG c.q.m.payment.order.GlobalRefundOrderMapper.test - <== Total:
-- ::06.256 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@22fb4694]
-- ::06.256 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Fetched SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@18b9642b] from current transaction
-- ::06.256 [http-nio--exec-] DEBUG c.q.m.read.order.TenVipOrderReadingMapper.test - ==> Preparing: update ten_vip_order_reading set order_status = where reading_vip_order_id =
-- ::06.257 [http-nio--exec-] DEBUG c.q.m.read.order.TenVipOrderReadingMapper.test - ==> Parameters:
-- ::06.367 [http-nio--exec-] DEBUG c.q.m.read.order.TenVipOrderReadingMapper.test - <== Updates:
-- ::06.367 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@18b9642b]
-- ::06.368 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@18b9642b]
-- ::06.368 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@18b9642b]
-- ::06.368 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@22fb4694]
-- ::06.368 [http-nio--exec-] DEBUG org.mybatis.spring.SqlSessionUtils - Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@22fb4694]
-- ::06.368 [http-nio--exec-] DEBUG o.springframework.jdbc.datasource.DataSourceUtils - Returning JDBC Connection to DataSource
-- ::06.368 [http-nio--exec-] DEBUG o.s.jdbc.datasource.DataSourceTransactionManager - Initiating transaction rollback
-- ::06.368 [http-nio--exec-] DEBUG o.s.jdbc.datasource.DataSourceTransactionManager - Rolling back JDBC transaction on Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@3a6cc709]
-- ::06.477 [http-nio--exec-] DEBUG o.s.jdbc.datasource.DataSourceTransactionManager - Releasing JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@3a6cc709] after transaction
-- ::06.477 [http-nio--exec-] DEBUG o.springframework.jdbc.datasource.DataSourceUtils - Returning JDBC Connection to DataSource
-- ::06.479 [http-nio--exec-] DEBUG o.s.w.s.m.m.a.ExceptionHandlerExceptionResolver - Resolving exception from handler [java.lang.String com.qing.controller.TestController.test()]: java.lang.RuntimeException: test
-- ::06.480 [http-nio--exec-] DEBUG o.s.b.factory.support.DefaultListableBeanFactory - Returning cached instance of singleton bean 'qingControllerAdvice'
-- ::06.480 [http-nio--exec-] DEBUG o.s.w.s.m.m.a.ExceptionHandlerExceptionResolver - Invoking @ExceptionHandler method: public com.qingread.utils.generate.RestGenerator<?> com.qing.controller.aop.QingControllerAdvice.errorHandler(java.lang.Exception)
-- ::06.483 [http-nio--exec-] ERROR com.qing.controller.aop.QingControllerAdvice - java.lang.RuntimeException: test
at com.qing.service.test.TestService.test(TestService.java:)

由日志可以知道用的JDBC Connection

-- ::04.588 [http-nio--exec-] DEBUG o.s.jdbc.datasource.DataSourceTransactionManager - Switching JDBC Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@3a6cc709] to manual commit

注意最后的回滚语句

-- ::06.368 [http-nio--exec-] DEBUG o.s.jdbc.datasource.DataSourceTransactionManager - Rolling back JDBC transaction on Connection [com.alibaba.druid.proxy.jdbc.ConnectionProxyImpl@3a6cc709]

代码结果是什么,你懂的

通过日志来看Spring跨库更新操作的事务的更多相关文章

  1. Spring Data Jpa 更新操作

    第一步,通过Repository对象把实体根据ID查询出来 第二部,往查出来的实体对象进行set各个字段 第三步,通过Repository接口的save方法进行保存 保存和更新方式(已知两种) 第一种 ...

  2. Hibernate-数据库更新操作

    /* Session接口下操作存在以下问题: 数据更新操作: 1.更新的时候必须要有主键; 2.若只更新部分字段内容,则未设置的字段将被设置为Null(全表更新) 3.update()没有返回值,即不 ...

  3. 一条跨库更新数据的sql

    UPDATE [db1].[dbo].[R_ResAndBook]     SET SectionID=TT2.newsecidFROM [SmartCampus].[dbo].[R_ResAndBo ...

  4. Spring Boot学习——数据库操作及事务管理

    本文讲解使用Spring-Data-Jpa操作数据库. JPA定义了一系列对象持久化的标准. 一.在项目中使用Spring-Data-Jpa 1. 配置文件application.properties ...

  5. sql server service broker中调用存储过程执行跨库操作,不管怎么设置都一直提示 服务器主体 "sa" 无法在当前安全上下文下访问数据库 "dbname"。

    用sql server自带的消息队列service borker,调用存储过程中,执行了一个跨库的操作,先是用了一个用户,权限什么都给够了,但是一直提示 服务器主体 "user" ...

  6. mysql跨库复制: replicate_wild_do_table和replicate-wild-ignore-table

    使用replicate_do_db和replicate_ignore_db时有一个隐患,跨库更新时会出错. 如设置 replicate_do_db=testuse mysql;update test. ...

  7. SQL Server 跨库查询

    1. 开启Ad Hoc Distributed Queries组件,在sql查询编辑器中执行如下语句: reconfigure reconfigure 2. 跨库查询操作 select * from ...

  8. 如何玩转跨库Join?跨数据库实例查询应用实践

    背景 随着业务复杂程度的提高.数据规模的增长,越来越多的公司选择对其在线业务数据库进行垂直或水平拆分,甚至选择不同的数据库类型以满足其业务需求.原本在同一数据库实例里就能实现的SQL查询,现在需要跨多 ...

  9. sql server 跨库操作

    SELECT *FROM OPENDATASOURCE('SQLOLEDB','Data Source=sql服务器名;User ID=用户名;Password=密码;').PersonDb.dbo. ...

随机推荐

  1. 51Nod - 1433 0和5 找规律

    小K手中有n张牌,每张牌上有一个一位数的数,这个字数不是0就是5.小K从这些牌在抽出任意张(不能抽0张),排成一行这样就组成了一个数.使得这个数尽可能大,而且可以被90整除. 注意: 1.这个数没有前 ...

  2. 使用 ReSharper,输入即遵循 StyleCop 的代码格式化规范

    使用 ReSharper,输入即遵循 StyleCop 的代码格式化规范 StyleCop 可以帮助强制执行代码格式化规范,ReSharper 可以帮助你更高效地编写代码.把两者结合起来,你便能高效地 ...

  3. Javascript 3.2

    对象的三种类型:1.用户定义对象:程序员自己创建的对象 2.内建对象:Javascript语言中的固定对象,如Array/Math/Data等 3.宿主对象:由浏览器提供的对象 BOM:浏览器对象模型 ...

  4. RXJS 实例操作符

    先来了解几个新名词: Observable : 可观察对象,是一组值或事件的集合 Observer : 观察者,回调函数集合 Subscription :Observable动作执行者 Operato ...

  5. robotframework之用cmd去执行用例

    1.电脑cmd进入 2.在cmd中输入相应的执行命令即可以正常执行 3.执行完成,会显示当前用例执行情况,以及output/log/report的默认保存路径 接下来详细说一下执行不同用例的具体指令, ...

  6. ST&倍增LCA

    回顾st算法,它的一大功能是求区间最值.先将整个区间划分成若干个小的区间,求出最值,然后将小的区间合并成一个大的区间,我们这里要用到一个数组minn[i][j],划重点!如果我们要求的是区间最小值,m ...

  7. axios delete

  8. haproxy反向代理

    haproxy是个高性能的tcp和http的反向代理.它就是个代理.不像nginx还做web服务器 官网地址为www.haproxy.org nginx的优点和缺点 优点: 1.web服务器,应用比较 ...

  9. 03day->python基本数据类型

    基本数据类型 1.数字(int)     a = 5     a.bit_length()  # 查看数字实际用到的bit位 2.布尔值(bool)     用于条件判断 3.字符串(str)     ...

  10. linux后台执行命令:&与nohup的用法

    & 这种方法很简单,就是在命令之后加个“&”符号就可以了,如下: ./test & 这样一来,test程序就在后台运行了.但是,这样处理还不够,因为这样做虽然程序是在后台运行了 ...