SqlSessionTemplate详解——Mybatis+Spring Boot整合

SqlSessionTemplate详解——Mybatis+Spring Boot整合Mybatis+SpringBoot整合——SqlSessionTemplate简介通俗地讲,SqlSessionTemplate是Mybatis—Spring的核心,是用来代替默认Mybatis实现的DefaultSqlSessionFactory,也可以说是DefaultSqlSessionFactory的优化版,主要负责管理Mybatis的SqlSession,调用Mybatis的sq…

大家好,又见面了,我是你们的朋友全栈君。

SqlSessionTemplate简介

通俗地讲,SqlSessionTemplate是Mybatis—Spring的核心,是用来代替默认Mybatis实现的DefaultSqlSessionFactory,也可以说是DefaultSqlSessionFactory的优化版,主要负责管理Mybatis的SqlSession,调用Mybatis的sql方法,SqlSessionTemplate是线程安全的,通过TransactionSynchronizationManager中的ThreadLocal保存线程对应的SqlSession,可以被多个Dao共享使用。

主要类变量

字段 类型 描述
sqlSessionFactory SqlSessionFactory SqlSession工厂
executorType ExecutorType Executor的类型:SIMPLE, REUSE, BATCH
sqlSessionProxy SqlSession SqlSession代理对象,注册了SqlSessionInterceptor反射处理器,实际上的方法调用都是通过SqlSessionInterceptor反射实现的。
exceptionTranslator PersistenceExceptionTranslator Spring提供的接口,用于处理持久化框架的异常

源码解析(内容枯燥,无兴趣可以直接跳过看实现方式!)

  • 从下面图片中可以看出,SqlSessionTemplate实现了SqlSession接口和DisposableBean接口,SqlSession这个不用多说,是用来实现对数据库的CURD操作的,相当于JDBC的Connection对象。
    直接输入1次#,并按下space后,将生成1级标题。输入2次#,并按下space后,将生成2级标题。以此类推,我们支持6级标题。有助于使用语法后生成一个完美的目录。

  • 另一个就是DisposableBean接口了,这个接口就有点意思了,首先声明一点,SqlSessionTemplate是Mybatis为了接入Spring提供的Bean,既然是Bean那肯定会执行初始化操作,Spring为初始化Bean提供了两种方式,一种是实现InitializingBean接口重写里面的afterPropertiesSet方法,第二种是配置文件中通过init-method指定afterPropertiesSet方法,两种方法都能完成Bean的初始化操作,那DisposableBean接口又是干嘛的呢,看下图,该接口只有一个方法,根据方法的名字,应该能猜出一些了,是在Bean完成初始化之后,对象销毁的时候用的,跟初始化Bean对应的,销毁对象也有两种方法,第一就是调用DisposableBean中的destroy方法,第二种就是在配置文件中的destroy-method,这个配置跟init-method相对应,在调用销毁的时候先调用DisposableBean的destroy方法,后执行destroy-method指定的方法。
    在这里插入图片描述

SqlSessionTemplate实现方式

  • 一般SpringBoot项目在创建的时候都可以选择Mybatis的依赖,如果没有下面代码可直接复制。
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.1</version>
</dependency>

  • Mybatis里面有提供SqlSessionTemplate,由于SpringBoot都是用的注解的方式注入,所以没有Spring-Mybatis.xml也就不需要配置,用Autowired直接自动注入即可。
    在这里插入图片描述
  • 看一下SqlSessionTemplate支持的方法,数据库的CURD四大操作都有,可以直接使用。
    在这里插入图片描述
  • 下面是代码,字符串str的值是Mapper文件namespace的值和id,obj则是传入的参数,用的Object比较方便。
/** * *查找对象 * @author XWJ * @return UserInfo * @class DaoImpl * @model findTheObject * @param str * @param ob * @return */
	public UserInfo findTheObject(String str,Object ob){ 
   
		return sqlSessionTemplate.selectOne(str, ob);
	}
	
	
  • 再下面则是Service调用
import javax.annotation.Resource;

import org.springframework.stereotype.Repository;

import com.xb.dao.DaoImpl;
import com.xb.util.EndData;

/** * @author XWJ *2019年10月10日 */
@Repository
public class TestService2 { 
   

	@Resource(name="daoImpl")
	private DaoImpl dao;
	
	
	public UserInfo getUserInfo(String id) throws Exception { 
   
		return (UserInfo)dao.findTheObject("TestMapper.getUserInfo", id);
		}
}

OK,到这里SqlSessionTemplate就解析完成 了,最后看都看了,码字不易,留个赞 再走吧!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/138477.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python基础(2)字符串常用方法[通俗易懂]

    python基础(2)字符串常用方法[通俗易懂]python字符串常用方法find(sub[,start[,end]])在索引start和end之间查找字符串sub​找到,则返回最左端的索引值,未找到,则返回-1​start和end都可

    2022年7月30日
    8
  • 项目实战:ASP.NET:B/S结构 个人空间相册、照片上传下载系统

    项目实战:ASP.NET:B/S结构 个人空间相册、照片上传下载系统项目实战:ASP.NET:B/S结构个人空间相册、照片上传下载系统编辑环境:win10_x64/VS2015/SqlServer2012项目:asp.net项目简介:只是具有基本的登录功能,上传相关信息,图片,提供下载,相册功能,熟悉表格和基本的前后台程序其他:这是写的第一个asp.net,只是为了熟悉和了解asp.net项目和相关的知识。本次只是简单地前台ht…

    2022年7月11日
    19
  • 微信小程序弹窗有输入框且可以使用名文和密文输入

    微信小程序弹窗有输入框且可以使用名文和密文输入wxml viewclass made box wx if passShow viewclass main viewclass title viewclass f f 请输入直播间密码 viewclass inputeara viewclass inputeara viewclass f f viewclass title viewclass main viewclass made box wx if passShow

    2025年10月22日
    6
  • vim 常用命令

    vim 常用命令普通命令模式复制内容功能需求操作说明复制全部文本按下ggyG复制完成,注意:G必须大写粘贴内容命令操作说明p通过箭头移动光标到需要粘贴的位置,按下p将内容粘贴到光标后面P按下P将内容粘贴到光标前面删除内容功能需求操作说明D删除游标所在位置的字符到行尾全选文本按下ggvG全选文本,但是最后一行仅选中第一个字符,按下ggVG才是真正的全选文本删除按下dG删除光标所在行以及下面的

    2022年5月9日
    41
  • php runtimeexception,Laravel框架运行出错提示RuntimeException No application encryption…「建议收藏」

    php runtimeexception,Laravel框架运行出错提示RuntimeException No application encryption…「建议收藏」关于Laravel,出错提示,RuntimeException,No,application,encryption,key,has,been,specified.,解决方法,Laravel框架运行出错提示RuntimeExceptionNoapplicationencryptionkeyhasbeenspecified解本文实例讲述了Laravel框架运行出错提示RuntimeExc…

    2022年7月18日
    12
  • mysql explain 无效[通俗易懂]

    mysql explain 无效[通俗易懂]最近分析一段sql是不是命中索引的,发现有的时候explain是可以的,有的时候又不行显然我们是要下面的结果。经过分析,原来是中间件的原因,直连mysql的可以用explain连mycat就不行。解决办法可以使用desc,也能达到同样效果…

    2022年10月17日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号