【java深入学习第1章】深入探究 MyBatis-Spring 中 SqlSession 的原理与应用
前言
在使用 MyBatis 进行持久层开发时,通常会与 Spring 框架集成,以便更好地管理事务和依赖注入。在 MyBatis-Spring 集成中,SqlSession
是一个非常重要的概念。本文将详细介绍 SqlSessionTemplate
和 SqlSessionDaoSupport
,并提供相关的代码示例。
一、SqlSessionTemplate
SqlSessionTemplate
是 MyBatis-Spring 提供的一个线程安全的 SqlSession
实现,用于执行 SQL 操作。它封装了 MyBatis 的 SqlSession
,并处理了事务的管理和资源的释放。
1. 创建
在 Spring 配置文件中,我们可以通过以下方式创建 SqlSessionTemplate
:
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath*:mappers/*.xml" />
</bean>
<bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="0" ref="sqlSessionFactory" />
</bean>
2. 使用
在 Spring 中,我们可以通过依赖注入的方式使用 SqlSessionTemplate
:
@Service
public class UserService {
@Autowired
private SqlSessionTemplate sqlSessionTemplate;
public User getUserById(int id) {
return sqlSessionTemplate.selectOne("com.example.mapper.UserMapper.selectUser", id);
}
}
3. 批量操作
在进行批量操作时,可以通过 SqlSessionTemplate
提供的批量操作方法来实现。
3.1 创建 SqlSessionTemplate
在 Spring 配置文件中创建 SqlSessionTemplate
的方式与前面相同:
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath*:mappers/*.xml" />
</bean>
<bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="0" ref="sqlSessionFactory" />
</bean>
3.2 Service
在 Service 层中,我们可以使用 SqlSessionTemplate
进行批量操作:
@Service
public class UserService {
@Autowired
private SqlSessionTemplate sqlSessionTemplate;
public void batchInsertUsers(List<User> users) {
sqlSessionTemplate.execute(new SqlSessionCallback<Void>() {
@Override
public Void doInSqlSession(SqlSession sqlSession) throws SQLException {
for (User user : users) {
sqlSession.insert("com.example.mapper.UserMapper.insertUser", user);
}
return null;
}
});
}
}
3.3 Controller
在 Controller 层中,我们可以调用 Service 层的方法进行批量操作:
@RestController
@RequestMapping("/users")
public class UserController {
@Autowired
private UserService userService;
@PostMapping("/batchInsert")
public ResponseEntity<Void> batchInsertUsers(@RequestBody List<User> users) {
userService.batchInsertUsers(users);
return ResponseEntity.ok().build();
}
}
二、SqlSessionDaoSupport
SqlSessionDaoSupport
是 MyBatis-Spring 提供的一个支持类,用于简化 DAO 层的开发。它提供了对 SqlSession
的支持,并可以通过继承该类来实现 DAO 层的功能。
使用示例
首先,我们需要创建一个继承 SqlSessionDaoSupport
的 DAO 类:
@Repository
public class UserDao extends SqlSessionDaoSupport {
@Autowired
public void setSqlSessionTemplate(SqlSessionTemplate sqlSessionTemplate) {
super.setSqlSessionTemplate(sqlSessionTemplate);
}
public User getUserById(int id) {
return getSqlSession().selectOne("com.example.mapper.UserMapper.selectUser", id);
}
public void insertUser(User user) {
getSqlSession().insert("com.example.mapper.UserMapper.insertUser", user);
}
}
在 Service 层中,我们可以通过依赖注入的方式使用 UserDao
:
@Service
public class UserService {
@Autowired
private UserDao userDao;
public User getUserById(int id) {
return userDao.getUserById(id);
}
public void insertUser(User user) {
userDao.insertUser(user);
}
}
总结
本文详细介绍了 MyBatis-Spring 中 SqlSessionTemplate
和 SqlSessionDaoSupport
的使用方法,并提供了相关的代码示例。通过使用 SqlSessionTemplate
,我们可以方便地进行 SQL 操作和批量操作;通过继承 SqlSessionDaoSupport
,我们可以简化 DAO 层的开发。希望本文对您在 MyBatis-Spring 集成开发中有所帮助。
百万大学生都在用的AI写论文工具,篇篇无重复AI写论文
【java深入学习第1章】深入探究 MyBatis-Spring 中 SqlSession 的原理与应用的更多相关文章
- Java EE 学习(7):IDEA + maven + spring 搭建 web(3)- 配置数据库
参考: https://my.oschina.net/gaussik/blog/513444 注:在阅读本文前,请先阅读: Java EE 学习(5):IDEA + maven + spring 搭建 ...
- Java开发学习心得(二):Mybatis和Url路由
目录 Java开发学习心得(二):Mybatis和Url路由 1.3 Mybatis 2 URL路由 2.1 @RequestMapping 2.2 @PathVariable 2.3 不同的请求类型 ...
- Java EE 学习(9):IDEA + maven + spring 搭建 web(5)- 博客文章管理
转载:Gaussic(一个致力于AI研究却不得不兼顾项目的研究生) . 注:在阅读本文前,请先阅读: Java EE 学习(5):IDEA + maven + spring 搭建 web(1) Jav ...
- Java EE 学习(8):IDEA + maven + spring 搭建 web(4)- 用户管理
转载:Gaussic(一个致力于AI研究却不得不兼顾项目的研究生) 注:在阅读本文前,请先阅读: Java EE 学习(5):IDEA + maven + spring 搭建 web(1) ava E ...
- Java EE 学习(6):IDEA + maven + spring 搭建 web(2)- 配置 Spring
参考:https://my.oschina.net/gaussik/blog/513353 注:此文承接上一文:Java EE 学习(5):IDEA + maven + spring 搭建 web(1 ...
- Java EE 学习(5):IDEA + maven + spring 搭建 web(1)
参考:http://www.cnblogs.com/lonelyxmas/p/5397422.html http://www.ctolib.com/docs-IntelliJ-IDEA-c--1590 ...
- 设计模式学习(二十四):Spring 中使用到的设计模式
设计模式学习(二十四):Spring 中使用到的设计模式 作者:Grey 原文地址: 博客园:设计模式学习(二十四):Spring 中使用到的设计模式 CSDN:设计模式学习(二十四):Spring ...
- Java开发学习(三十九)----SpringBoot整合mybatis
一.回顾Spring整合Mybatis Spring 整合 Mybatis 需要定义很多配置类 SpringConfig 配置类 导入 JdbcConfig 配置类 导入 MybatisConfig ...
- spring学习笔记(四)我对spring中bean生命周期的理解
我相信大部分同学对spring中bean的生命周期都不陌生,但是如果要详细的说出每一个步骤,可能能说出来的也不多,我之前也是这样,前几天调了一下spring的源码,看了一点书,突然一下明朗了,理解了s ...
- Java JDK8 学习笔记 1-3章
第一章 Java平台概论 1.了解Java的前世今生,Java SE.Java EE.JavaME三大平台.其中Java SE主要由四部分JVM.JRE.JDK与Java语言,JDK包含JRE,JRE ...
随机推荐
- C 语言编程 — 高级数据类型 — 字符串
目录 文章目录 目录 前文列表 字符串 前文列表 <程序编译流程与 GCC 编译器> <C 语言编程 - 基本语法> <C 语言编程 - 基本数据类型> <C ...
- linux下YUM工具的使用:yum安装/升级/查看/搜索/卸载软件包
目录 一.关于软件包 二.关于YUM 三.yum工具的使用 3.1 yum安装软件功能 3.2 yum升级软件包功能 3.3 yum查看,搜索功能 3.4 yum卸载功能 3.5 yum安装软件包组功 ...
- minio 安装
mybatis 相关:https://baomidou.com/pages/223848/#fieldfillhttps://mybatis-flex.com/zh/intro/maven.html ...
- IceRPC之深入理解调度管道->快乐的RPC
作者引言 很高兴啊,我们来到了IceRPC之深入理解调度管道->快乐的RPC,为上篇的续篇,深入理解常见的调度类型, 基础引导,有点小压力,打好基础,才能让自已不在迷茫,快乐的畅游世界. 传入请 ...
- 如何从0-1了解 熟悉 精通gitlab
加入gitlab团队项目: 打开其他用户极狐邀请邮件: 点击接受紫色邀请按钮"accept invitation": 选择免费试用90天saas服务: 使用邮箱注册进行邮箱验证[验 ...
- golang 怎么获取kubernetes deployments的状态?
如果我们需要把k8s的信息展示为一个友好的web页面.那么deployment 的信息基本上是非常重要的(大部分的服务都是使用deployment部署). 从yaml 中我们能获取到很多关于deplo ...
- TensorRT环境配置(VS+opencv4.5)
1 TensorRT下载 下载与TensorRT相匹配的CUDA和cuDNN版本:https://docs.nvidia.com/deeplearning/tensorrt/archives/tens ...
- 记第一次用python写界面
花了两三个小时学了Tkinter,做了一个将数据绘制成图的小工具. 1. 获取路径下的所有文件or获取路径下指定名称的文件 1.1 打开文件 //1. 用来放文本框中的文字filename = St ...
- k8s核心组件详解和分层架构
k8s核心组件 master中的核心组件 api-server(接口服务,基于rest风格开放k8s接口的服务) kube-controller-manager(管理各个类型的控制器,针对k8s中的各 ...
- mac home目录下无法mkdir目录及文件的解决方法
主要参考以下几篇文章 https://www.cnblogs.com/zhangbao3/p/12600058.html https://www.v2ex.com/t/607387 https://w ...