MyBatis原理分析
你翻开 SqlSession 的源码,你会发现它只是一个接口。我们通过 MyBatis 操作数据库,实际上就是通过 SqlSession 获取一个 JDBC 链接,然后操作数据库。但 SqlSession 是一个接口,怎么操作?
SqlSession 虽然是一个接口,但它有好几个实现类。比如:DefaultSqlSession、SqlSessionManager、SqlSessionTemplate 等
DefaultSqlSession 不是线程安全的。而根据它的名字,我们就应该知道 MyBatis 在默认情况下,使用的就是 DefaultSqlSession。既然 DefaultSqlSession 不是线程安全的,所以你在使用它的时候,切记不能把它设为单例。
SqlSessionManager 是由调用者决定是否共用 SqlSession 的。而 SqlSessionTemplate 是 MyBatis 专门为 Spring 提供的,支持 Spring 框架的一个 SqlSession 获取接口。主要是为了继承 Spring,并同时将是否共用 SqlSession 的权限交给 Spring 去管理。
这一点,我们通过它们所在包的命令也可以看出来。org.mybatis.spring.SqlSessionTemplate 一看包名就知道,它是为嫁接 Spring 而提供的。并且它实现了 Spring 的 DisposableBean 接口。
SqlSessionManager 是适合在不整合 Spring 框架的时候使用。并且是在一开始,2009 年就推出了这个类。但是自从有了 Spring,配合 Spring 以后,SqlSessionTemplate 类就逐渐取代了 SqlSessionManager。
大家在使用 MyBatis 时,基本上都是会和 Spring 进行继承的。因此 SqlSessionManager 基本上被抛弃,目前各个开源项目中基本上都没有见到 SqlSessionManager 的身影。为了和 Spring 能够更好的整合,因此,我们都是用 SqlSessionTemplate 来获取 SqlSession。
https://blog.****.net/weixin_43184769/article/details/91126687
https://www.xttblog.com/?p=4041 Mybatis 不是有 SqlSessionManager 了吗?为什么有提供了SqlSessionTemplate?
https://www.xttblog.com/?p=4020 MyBatis 中 SqlSession 是线程安全的吗?