当前位置: 首页 > news >正文

SpringBoot(九)之整合mybatis

SpringBoot(九)之整合mybatis

文章目录

    • SpringBoot(九)之整合mybatis
      • Spring整合mybatis回顾
        • 1. 引入依赖
        • 2. mybatis-config.xml
      • SpringBoot整合mybatis
        • 1.引入依赖
        • 2. 配置数据源和 MyBatis 属性
        • 3. 配置 Mapper 接口
        • 4. 配置mapper.xml
        • 5. 使用 `@Transactional` 注解

Spring整合mybatis回顾

原生Spring中整合mybatis主要是将SqlSessionFactoryBean交给Spring管理。下面来回顾一下

1. 引入依赖
	<dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>2.1.0</version></dependency><!-- MyBatis --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.10</version></dependency><!-- MySQL Connector --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.27</version></dependency>
2. mybatis-config.xml
<!-- DataSource配置 --><bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"><property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://192.168.56.102:3306/boot-test"/><property name="username" value="root"/><property name="password" value="123456"/></bean><!-- MyBatis SqlSessionFactory配置 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="dataSource"/><property name="mapperLocations" value="classpath:mapper/*Mapper.xml"/></bean><!-- MyBatis SqlSessionTemplate配置 --><bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate"><constructor-arg index="0" ref="sqlSessionFactory"/></bean><!-- Mapper接口扫描 --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="cn.axj.mybatis.mapper"/></bean><!-- 事务管理器配置 --><bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"/></bean><!--    开启事务管理器--><tx:annotation-driven transaction-manager="transactionManager"/>

Spring整合mybatis需要配置数据源事务管理器显示的开启事务管理器sqlSessionFacotryBean。感觉整个配置下来巨麻烦不说,还特别容易忘记。

SpringBoot整合mybatis

想比之下,SpringBoot默认帮我们开启了事务管理器,默认帮我们将sqlSessionFacotryBean注册到Spring容器中。我们只需要配置mapper.xml的文件路径以及mapper接口的路径(接口路径可不配置,但是需要在mapper接口上显示的加上@Mapepr注解)和数据库链接参数等信息。

涉及到SpringBoot的自动配置原理,以后再说。

1.引入依赖
		<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.2.2</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.16</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency>

mybatis-spring-boot-starter 可以简化在 Spring Boot 项目中集成 MyBatis 的过程,并且事务管理也会自动配置。在 Spring Boot 2.x 及以上版本中,只需添加相应的依赖和配置,即可启用事务管理。

2. 配置数据源和 MyBatis 属性
spring:datasource:druid:username: rootpassword: 123456url: jdbc:mysql://192.168.56.102:3306/boot-test?driver-class-name: com.mysql.cj.jdbc.Driverinitial-size: 5min-idle: 5max-active: 20max-wait: 60000time-between-eviction-runs-millis: 60000min-evictable-idle-time-millis: 300000validation-query: select 1 from dualtest-while-idle: truetest-on-borrow: falsetest-on-return: false
mybatis:mapper-locations: classpath:mapper/*.xmltype-aliases-package: cn.axj.boot.mybatis.model.beanconfiguration:map-underscore-to-camel-case: true
3. 配置 Mapper 接口

确保你的 Mapper 接口和 XML 映射文件配置正确。例如,创建一个简单的 Mapper 接口

@Mapper
public interface SysUserMapper {int insertUser(SysUser sysUser);SysUser getUserById(Integer id);
}

可通过在SpringBoot配置类上手动加上@MapperScan(basePackages = “cn.axj.boot.mybatis.mapper”)定义mapper接口路径,在创建mapper接口的时候可不用加上@Mapper注解

4. 配置mapper.xml

按照配置在resources目录下创建mapper文件夹,创建一个简单的mapper.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="cn.axj.boot.mybatis.mapper.SysUserMapper"><insert id="insertUser">insert into sys_user(id, name, age) values(#{id}, #{name}, #{age})</insert><select id="getUserById" resultType="cn.axj.boot.mybatis.model.bean.SysUser">select * from sys_user where id = #{id}</select>
</mapper>
5. 使用 @Transactional 注解
@Service
public class SysUserService {@Resourceprivate SysUserMapper sysUserMapper;@Transactional(rollbackFor = Exception.class)public void testTrans(){SysUser sysUser = new SysUser();sysUser.setName("test");sysUser.setAge(23);sysUserMapper.insertUser(sysUser);int i = ThreadLocalRandom.current().nextInt(10);SysUser userById = sysUserMapper.getUserById(i);if(Objects.isNull(userById)){throw new RuntimeException("查询结果为空");}}
}

相关文章:

  • Texstudio——设置实时自动更新PDF的方法
  • 使用curl发送http请求
  • 网络安全架构之零信任安全
  • 【热门话题】一文带你读懂公司是如何知道张三在脉脉上发了“一句话”的
  • 面试总结之:socket线路切换
  • 抖音视频怎么去水印保存部分源码|短视频爬虫提取收集下载工具
  • zdppy_validate数据校验工具入门
  • k8s集群安装后CoreDNS 启动报错plugin/forward: no nameservers found
  • c++读取文本文件出现乱码问题
  • 2024.05.24|生信早报【AI测试版】
  • 2. C++服务器编程-信号
  • MobaXterm使用私钥远程登陆linux
  • 分布式中traceId链接服务间的日志
  • 短剧系统源码解析与应用
  • 详细分析Vue3中的emit用法(子传父)
  • Django 博客开发教程 8 - 博客文章详情页
  • express如何解决request entity too large问题
  • GraphQL学习过程应该是这样的
  • in typeof instanceof ===这些运算符有什么作用
  • input实现文字超出省略号功能
  • JS进阶 - JS 、JS-Web-API与DOM、BOM
  • Protobuf3语言指南
  • Service Worker
  • socket.io+express实现聊天室的思考(三)
  • WinRAR存在严重的安全漏洞影响5亿用户
  • 大主子表关联的性能优化方法
  • 多线程 start 和 run 方法到底有什么区别?
  • 我感觉这是史上最牛的防sql注入方法类
  • 译有关态射的一切
  • 在Unity中实现一个简单的消息管理器
  • ​Java并发新构件之Exchanger
  • ​一、什么是射频识别?二、射频识别系统组成及工作原理三、射频识别系统分类四、RFID与物联网​
  • #Java第九次作业--输入输出流和文件操作
  • #Z0458. 树的中心2
  • (M)unity2D敌人的创建、人物属性设置,遇敌掉血
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (附源码)ssm智慧社区管理系统 毕业设计 101635
  • (力扣)循环队列的实现与详解(C语言)
  • (原創) 博客園正式支援VHDL語法著色功能 (SOC) (VHDL)
  • *2 echo、printf、mkdir命令的应用
  • ... fatal error LINK1120:1个无法解析的外部命令 的解决办法
  • .NET Compact Framework 3.5 支持 WCF 的子集
  • .NET Core MongoDB数据仓储和工作单元模式封装
  • .net core 依赖注入的基本用发
  • .NET Framework、.NET Core 、 .NET 5、.NET 6和.NET 7 和.NET8 简介及区别
  • .net 桌面开发 运行一阵子就自动关闭_聊城旋转门家用价格大约是多少,全自动旋转门,期待合作...
  • .NetCore Flurl.Http 升级到4.0后 https 无法建立SSL连接
  • .NET开发不可不知、不可不用的辅助类(一)
  • .set 数据导入matlab,设置变量导入选项 - MATLAB setvaropts - MathWorks 中国
  • .skip() 和 .only() 的使用
  • :O)修改linux硬件时间
  • [].shift.call( arguments ) 和 [].slice.call( arguments )
  • [Android 数据通信] android cmwap接入点
  • [Android]如何调试Native memory crash issue
  • [javaSE] 看知乎学习工厂模式