深入解析Spring Boot集成MyBatis的多种方式

文章目录

    • 1. 引言
    • 2. 传统的XML配置方式
      • 2.1 引入依赖
      • 2.2 配置数据源和MyBatis
      • 2.3 编写Mapper接口和XML映射文件
      • 2.4 使用Mapper
    • 3. 注解配置方式
      • 3.1 引入依赖
      • 3.2 配置数据源和MyBatis
      • 3.3 编写Mapper接口
      • 3.4 使用Mapper
    • 4. MyBatis动态SQL
      • 4.1 使用XML配置方式
      • 4.2 使用注解配置方式
    • 5. MyBatis的插件机制
    • 6. 性能优化与拓展
      • 6.1 缓存机制
      • 6.2 批量操作
      • 6.3 多数据源配置
    • 7. 总结

在这里插入图片描述

🎉欢迎来到架构设计专栏~深入解析Spring Boot集成MyBatis的多种方式


  • ☆* o(≧▽≦)o *☆嗨~我是IT·陈寒🍹
  • ✨博客主页:IT·陈寒的博客
  • 🎈该系列文章专栏:架构设计
  • 📜其他专栏:Java学习路线 Java面试技巧 Java实战项目 AIGC人工智能 数据结构学习
  • 🍹文章作者技术和水平有限,如果文中出现错误,希望大家能指正🙏
  • 📜 欢迎大家关注! ❤️

1. 引言

Spring Boot作为一款快速开发、简化配置的框架,与MyBatis的结合使用是开发中常见的组合。本文将深入探讨Spring Boot集成MyBatis的多种方式,包括XML配置、注解配置以及MyBatis的动态SQL等,通过实例代码和详细解释,帮助读者选择适合自己项目的集成方式。
在这里插入图片描述

2. 传统的XML配置方式

2.1 引入依赖

首先,在pom.xml文件中添加MyBatis和数据库驱动的依赖:

<dependencies><!-- MyBatis --><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.2.0</version></dependency><!-- 数据库驱动 --><dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><scope>runtime</scope></dependency>
</dependencies>

2.2 配置数据源和MyBatis

application.propertiesapplication.yml中配置数据源和MyBatis:

spring:datasource:driver-class-name: org.h2.Driverurl: jdbc:h2:mem:testdbusername: sapassword:h2:console:enabled: truemybatis:mapper-locations: classpath:/mapper/*.xml

在上述配置中,spring.datasource用于配置数据源,mybatis.mapper-locations指定了MyBatis的XML映射文件的位置。

2.3 编写Mapper接口和XML映射文件

创建一个User实体类:

public class User {private Long id;private String username;private String password;// 省略getter和setter
}

创建一个UserMapper接口:

public interface UserMapper {User selectUserById(Long id);void insertUser(User user);
}

编写UserMapper的XML映射文件UserMapper.xml

<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.UserMapper"><resultMap id="BaseResultMap" type="com.example.entity.User"><id column="id" property="id" jdbcType="BIGINT" /><result column="username" property="username" jdbcType="VARCHAR" /><result column="password" property="password" jdbcType="VARCHAR" /></resultMap><select id="selectUserById" resultMap="BaseResultMap">SELECT * FROM user WHERE id = #{id}</select><insert id="insertUser">INSERT INTO user (username, password) VALUES (#{username}, #{password})</insert></mapper>

2.4 使用Mapper

在Service或Controller中使用UserMapper:

@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public User getUserById(Long id) {return userMapper.selectUserById(id);}public void createUser(User user) {userMapper.insertUser(user);}
}

这样,通过XML配置方式,我们完成了Spring Boot与MyBatis的集成。

3. 注解配置方式

3.1 引入依赖

同样,在pom.xml文件中添加MyBatis和数据库驱动的依赖:

<dependencies><!-- MyBatis --><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.2.0</version></dependency><!-- 数据库驱动 --><dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><scope>runtime</scope></dependency>
</dependencies>

3.2 配置数据源和MyBatis

application.propertiesapplication.yml中配置数据源和MyBatis:

spring:datasource:driver-class-name: org.h2.Driverurl: jdbc:h2:mem:testdbusername: sapassword:h2:console:enabled: truemybatis:mapper-locations: classpath:/mapper/*.xml

3.3 编写Mapper接口

创建一个UserMapper接口,并使用注解配置SQL语句:

@Mapper
public interface UserMapper {@Select("SELECT * FROM user WHERE id = #{id}")User selectUserById(Long id);@Insert("INSERT INTO user (username, password) VALUES (#{username}, #{password})")void insertUser(User user);
}

3.4 使用Mapper

在Service或Controller中使用UserMapper:

@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public User getUserById(Long id) {return userMapper.selectUserById(id);}public void createUser(User user) {userMapper.insertUser(user);}
}

通过注解配置方式,我们实现了Spring Boot与MyBatis的集成,使得Mapper接口的SQL语句更加直观。

4. MyBatis动态SQL

4.1 使用XML配置方式

动态SQL是MyBatis的一个强大特性,可以根据不同条件拼接SQL语句,从而实现更加灵活的查询。下面是一个简单的例子,使用MyBatis的动态SQL:

<!-- UserMapper.xml --><mapper namespace="com.example.mapper.UserMapper"><select id="selectUsersByCondition" parameterType="java.util.Map" resultType="com.example.entity.User">SELECT * FROM user<where><if test="username != null">AND username = #{username}</if><if test="age != null">AND age = #{age}</if></where></select></mapper>

在上述代码中,我们使用<where>标签包裹条件判断,通过<if>标签判断是否需要拼接对应的条件语句。

4.2 使用注解配置方式

通过注解配置方式使用动态SQL:

// UserMapper.java@Mapper
public interface UserMapper {@SelectProvider(type = UserSqlProvider.class, method = "selectUsersByCondition")List<User> selectUsersByCondition(Map<String, Object> condition);
}
// UserSqlProvider.javapublic class UserSqlProvider {public String selectUsersByCondition(Map<String, Object> condition) {return new SQL() {{SELECT("*");FROM("user");if (condition.get("username") != null) {WHERE("username = #{username}");}if (condition.get("age") != null) {WHERE("age = #{age}");}}}.toString();}
}

在上述代码中,通过@SelectProvider注解指定了使用的Provider类和方法,Provider类中动态生成SQL语句。

5. MyBatis的插件机制

MyBatis提供了插件机制,可以通过插件对SQL的执行过程进行干预和增强。以下是一个简单的插件示例:

// MyPlugin.java@Intercepts({@Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class})
})
public class MyPlugin implements Interceptor {@Overridepublic Object intercept(Invocation invocation) throws Throwable {// 在原方法执行前进行处理System.out.println("Before update...");// 调用原方法Object result = invocation.proceed();// 在原方法执行后进行处理System.out.println("After update...");return result;}@Overridepublic Object plugin(Object target) {// 将插件应用到Executor对象上return Plugin.wrap(target, this);}@Overridepublic void setProperties(Properties properties) {// 设置插件属性}
}

在上述代码中,通过@Intercepts@Signature注解指定了拦截的方法和参数类型,实现了Interceptor接口。在intercept方法中可以对原方法进行干预,plugin方法将插件应用到目标对象上。

6. 性能优化与拓展

6.1 缓存机制

MyBatis提供了一级缓存和二级缓存两种缓存机制。一级缓存是SqlSession级别的缓存,而二级缓存是Mapper级别的缓存。在需要优化查询性能时,可以考虑使用MyBatis的缓存机制。

6.2 批量操作

MyBatis支持批量插入、更新和删除操作,通过批量操作可以减少数据库交互次数,提高性能。

6.3 多数据源配置

在实际项目中,可能会遇到需要连接多个数据源的情况。Spring Boot和MyBatis提供了多数据源的支持,可以通过配置多个DataSourceSqlSessionFactory来实现。

7. 总结

本文深入解析了Spring Boot集成MyBatis的多种方式,包括XML配置、注解配置以及MyBatis的动态SQL等。通过实例代码和详细解释,读者能够更好地理解这些集成方式的使用场景和优劣。同时,了解了MyBatis的插件机制、缓存机制以及一些性能优化的方法。在实际项目中,根据具体需求选择合适的集成方式和优化策略,能够更好地发挥Spring Boot和MyBatis的优势,提升开发效率和系统性能。


🧸结尾 ❤️ 感谢您的支持和鼓励! 😊🙏
📜您可能感兴趣的内容:

  • 【Java面试技巧】Java面试八股文 - 掌握面试必备知识(目录篇)
  • 【Java学习路线】2023年完整版Java学习路线图
  • 【AIGC人工智能】Chat GPT是什么,初学者怎么使用Chat GPT,需要注意些什么
  • 【Java实战项目】SpringBoot+SSM实战:打造高效便捷的企业级Java外卖订购系统
  • 【数据结构学习】从零起步:学习数据结构的完整路径

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/219027.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt/C++视频监控安卓版/多通道显示视频画面/录像存储/视频播放安卓版/ffmpeg安卓

一、前言 随着监控行业的发展&#xff0c;越来越多的用户场景是需要在手机上查看监控&#xff0c;而之前主要的监控系统都是在PC端&#xff0c;毕竟PC端屏幕大&#xff0c;能够看到的画面多&#xff0c;解码性能也强劲。早期的手机估计性能弱鸡&#xff0c;而现在的手机性能不…

Facebook广告系统结构

Facebook广告系统是一个复杂的大型系统&#xff0c;由多个组件和子系统相互配合工作&#xff0c;实现了广告的投放、拍卖、个性化推荐和效果评估等功能。下面小编讲讲Facebook广告系统的结构。 1、广告管理界面 广告管理界面是广告主与Facebook进行交互的入口&#xff0c;广告…

如何在Docker部署draw.io流程图软件并实现公网远程访问

前言 提到流程图&#xff0c;大家第一时间可能会想到Visio&#xff0c;不可否认&#xff0c;VIsio确实是功能强大&#xff0c;但是软件为收费&#xff0c;并且因为其功能强大&#xff0c;导致安装需要很多的系统内存&#xff0c;并且是不可跨平台使用。所以&#xff0c;今天给…

c语言链表的基本操作

在C语言中&#xff0c;链表是一种常见的数据结构&#xff0c;它由一系列节点组成&#xff0c;每个节点包含一个数据元素和一个指向下一个节点的指针。链表的基本操作包括创建、插入、删除和遍历等。 下面是一个简单的链表节点结构体定义&#xff1a; struct Node { int da…

Leaflet.Graticule源码分析以及经纬度汉化展示

目录 前言 一、源码分析 1、类图设计 2、时序调用 3、调用说明 二、经纬度汉化 1、改造前 2、汉化 3、改造效果 总结 前言 在之前的博客基于Leaflet的Webgis经纬网格生成实践中&#xff0c;已经深入介绍了Leaflet.Graticule的实际使用方法和进行了简单的源码分析。认…

C语言之函数式宏

目录 函数和数据类型 函数式宏 函数和函数式宏 函数式宏和对象式宏 不带参数的函数式宏 函数式宏和逗号运算符 函数式宏和函数类似并且比函数更加灵活&#xff0c;下面我们就来学习函数式宏的相关内容。 函数和数据类型 我们来编写一个程序&#xff0c;它能计算出所读取…

『PyTorch』张量和函数之gather()函数

文章目录 PyTorch中的选择函数gather()函数 参考文献 PyTorch中的选择函数 gather()函数 import torch a torch.arange(1, 16).reshape(5, 3) """ result: a [[1, 2, 3],[4, 5, 6],[7, 8, 9],[10, 11, 12],[13, 14, 15]] """# 定义两个index…

注册与回调

C 再谈谈注册(本质是建立映射)与回调 在之前的博文中&#xff0c; 我们探讨过映射的重要作用&#xff0c; 请直接看&#xff1a;http://blog.csdn.net/stpeace/article/details/39452203, 在那篇文章中&#xff0c; 我们是用STL中的map来做的&#xff0c; map建立的是key-value…

ChatGLM-6B模型结构组件源码阅读

一、前言 本文将介绍ChatGLM-6B的模型结构组件源码。 代练链接&#xff1a;https://huggingface.co/THUDM/chatglm-6b/blob/main/modeling_chatglm.py 二、激活函数 torch.jit.script def gelu_impl(x):"""OpenAIs gelu implementation."""r…

云演 Can you getshell?

1、扫目录&#xff0c;看看到upload.php,找到上传点 2、只让上传jpg gif png&#xff0c;上传图片写码 <?php eval($_POST[c]);?>这个码不行 换马 <script language"php">eval($_REQUEST[c])</script>3、蚁剑连接、得到flag

【MyBatis-Plus】MyBatis进阶使用

目录 一、MyBatis-Plus简介 1.1 介绍 1.2 优点 1.3 结构 二、MyBatis-Plus基本使用 2.1 配置 2.2 代码生成 2.3 CRUD接口测试 三、MyBatis-Plus策略详解 3.1 主键生成策略 3.2 雪花ID生成器 3.3 字段自动填充策略 3.4 逻辑删除 四、MyBatis-Plus插件使用 4.1 乐…

TrustZone之完成器:外围设备和内存

到目前为止,在本指南中,我们集中讨论了处理器,但TrustZone远不止是一组处理器功能。要充分利用TrustZone功能,我们还需要系统其余部分的支持。以下是一个启用了TrustZone的系统示例: 本节探讨了该系统中的关键组件以及它们在TrustZone中的作用。 完成器:外围设备…

服务器数据恢复—raid5热备盘未激活崩溃导致上层oracle数据丢失的数据恢复案例

服务器数据恢复环境&#xff1a; 某品牌X系列服务器&#xff0c;4块SAS硬盘组建了一组RAID5阵列&#xff0c;还有1块磁盘作为热备盘使用。服务器上层安装的linux操作系统&#xff0c;操作系统上部署了一个基于oracle数据库的OA&#xff08;oracle已经不再为该OA系统提供后续服务…

【c语言】【visual studio】动态内存管理,malloc,calloc,realloc详解。

引言&#xff1a;随着大一期末的到来&#xff0c;想必许多学生都学到内存的动态管理这一部分了&#xff0c;看望这篇博客后&#xff0c;希望能解除你心中对这一章节的疑惑。 (・∀・(・∀・(・∀・*) 1.malloc详解 malloc的头文件是#include <sdtlib.h>,malloc - C Ref…

Spring Cloud + Vue前后端分离-第5章 单表管理功能前后端开发

Spring Cloud Vue前后端分离-第5章 单表管理功能前后端开发 完成单表的增删改查 控台单表增删改查的前后端开发&#xff0c;重点学习前后端数据交互&#xff0c;vue ajax库axios的使用等 通用组件开发:分页、确认框、提示框、等待框等 常用的公共组件:确认框、提示框、等待…

【Linux】多线程编程

目录 1. 线程基础知识 2. 线程创建 3. 线程ID&#xff08;TID&#xff09; 4. 线程终止 5. 线程取消 6. 线程等待 7. 线程分离 8. 线程互斥 8.1 初始化互斥量 8.2 销毁互斥量 8.3 互斥量加锁和解锁 9. 可重入和线程安全 10. 线程同步之条件变量 10.1 初始化条件变…

一文了解Tomcat

文章目录 1、Tomcat介绍2、Tomcat使用配置2.1、Tomcat下载启动2.2、Tomcat启动乱码2.3、Tomcat端口号修改 3、Tomcat项目部署4、IDEA中使用Tomcat方式 1、Tomcat介绍 什么是Tomcat ​ Tomcat是Apache软件基金会一个核心项目&#xff0c;是一个开源免费的轻量级web服务器&#x…

【算法Hot100系列】最长回文子串

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

【机器学习】应用KNN实现鸢尾花种类预测

目录 前言 一、K最近邻&#xff08;KNN&#xff09;介绍 二、鸢尾花数据集介绍 三、鸢尾花数据集可视化 四、鸢尾花数据分析 总结 &#x1f308;嗨&#xff01;我是Filotimo__&#x1f308;。很高兴与大家相识&#xff0c;希望我的博客能对你有所帮助。 &#x1f4a1;本文由Fil…

js基础入门

先来一点js基础&#xff0c;其实js大部分的时候都在处理对象或者数组。 对象四个基本操作&#xff1a;增删改查 掌握元素的增删改查&#xff0c;了解如何拷贝&#xff0c;深拷贝和浅拷贝的区别。详情见代码 <script>//创建对象一共有三种赋值声明的语法let obj{} //赋值…