mybatis深度解析3--拿到Connection

要知道这个问题,先得知道mybatis使用的数据源策略,共有三种

  • UNPOOLED 不使用数据源,每次创建会话都是新连接
  • POOLED 使用自己实现的连接池
  • JNDI 使用命名服务查找到的数据源,这和SPI机制是交集

这里小伙伴们就会发现一个问题了,就是数据源策略是Configuration对象中装配的,Configuration对象是被SqlSessionFactory对象长久持有的,我们每次创建会话都是靠SqlSessionFactory对象,如果出现多数据源或者数据源切换的场景要怎么办呢?
这个问题先放这里

我们继续看配置文件中有一行

<dataSource type="POOLED"> 

这个POOLED是可以换成druid或者其他数据源的,这里写的就是mybatis默认的数据源
再看看springboot整合druid的时候是配置文件中有一个type属性,springboot已经帮我们注入好了
然后源码获取的地方在这里,解析xml配置的时候一起就配置好啦
在这里插入图片描述

有了数据源,我们可以先看看mybatis自带的事务 org.apache.ibatis.transaction.Transaction
这个事务就是由SqlSessionFactory#openSession方法创建出来的
在这里插入图片描述

事务对象里面拿到了DataSource
在这里插入图片描述
这里则拿到了java提供的Connection

mybatis自己给这个接口实现了两个类:JdbcTransaction和ManagedTransaction
具体使用了哪个,我们在配置文件中做了配置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将SSM框架中的MyBatis升级到MyBatis-Plus是可行的,可以实现共存。SSM框架由SpringSpring MVC和MyBatis组成,而MyBatis-Plus是对MyBatis的增强扩展。下面将介绍如何将它们共存。 首先,需要将MyBatis升级到MyBatis-Plus。可以将MyBatis-Plus的依赖项添加到项目的pom.xml文件中,替换原有的MyBatis依赖。然后,需要对原有的MyBatis配置文件进行修改。MyBatis-Plus提供了一些方便的功能和特性,如自动填充、逻辑删除等,可以根据项目需求选择开启或关闭。 在SSM框架中,MyBatis-Plus可以与原有的Spring框架和Spring MVC框架完美共存。Spring框架负责管理和配置各种Bean,MyBatis-Plus可以与Spring框架一起使用,将其作为DAO层的组件进行管理。在Spring的配置文件中,可以将MyBatis-Plus的配置文件加入到配置中。 在Spring MVC框架中,可以继续使用原有的控制器、服务和视图解析器等组件。MyBatis-Plus可以与Spring MVC框架无缝集成,通过Spring MVC接收请求,然后调用MyBatis-Plus进行数据访问和处理。 在具体开发过程中,可以利用MyBatis-Plus提供的一些特性简化开发工作。例如,可以使用MyBatis-Plus的代码生成器来自动生成DAO、实体类和Mapper等代码,减少手动编写的工作量。 总结来说,将SSM框架中的MyBatis升级到MyBatis-Plus是完全可以实现的,它们可以共存并完美集成。通过使用MyBatis-Plus,我们可以更加便捷地开发和管理数据库操作,提高开发效率和代码质量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值