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

news2024/12/27 10:45:43

文章目录

    • 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.Driver
    url: jdbc:h2:mem:testdb
    username: sa
    password:
  h2:
    console:
      enabled: true
  mybatis:
    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 {

    @Autowired
    private 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.Driver
    url: jdbc:h2:mem:testdb
    username: sa
    password:
  h2:
    console:
      enabled: true
  mybatis:
    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 {

    @Autowired
    private 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.java

public 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 {

    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        // 在原方法执行前进行处理
        System.out.println("Before update...");

        // 调用原方法
        Object result = invocation.proceed();

        // 在原方法执行后进行处理
        System.out.println("After update...");

        return result;
    }

    @Override
    public Object plugin(Object target) {
        // 将插件应用到Executor对象上
        return Plugin.wrap(target, this);
    }

    @Override
    public 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.coloradmin.cn/o/1320055.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

laravel的安装

laravel的安装&#xff08;Composer小皮&#xff09; Composer的安装 windows下安装 https://getcomposer.org/Composer-Setup.exe 修改镜像 阿里云&#xff1a; composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/ 华为云&#xff1a; compos…

时序分解 | Matlab实现DBO-VMD基于蜣螂优化算法优化VMD变分模态分解时间序列信号分解

时序分解 | Matlab实现DBO-VMD基于蜣螂优化算法优化VMD变分模态分解时间序列信号分解 目录 时序分解 | Matlab实现DBO-VMD基于蜣螂优化算法优化VMD变分模态分解时间序列信号分解效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.利用蜣螂优化算法优化VMD中的参数k、a&…

带你了解OpenCV4工业缺陷检测的六种方法

文章目录 OpenCV4工业缺陷检测的六种方法机器视觉缺陷检测1. 工业上常见缺陷检测方法方法一&#xff1a;基于简单二值图像分析实现划痕提取&#xff0c;效果如下&#xff1a;方法二&#xff1a;复杂背景下的图像缺陷分析&#xff0c;基于频域增强的方法实现缺陷检测&#xff0c…

【工作流Activiti】Activiti流程操作

1、流程定义 我们定义一个请假流程 1.1、新建模型 1.2、开始节点 1.3、任务节点 1.4、结束节点 1.5、设置节点属性 指定标签名称&#xff1a;张三审批&#xff0c;节点任务负责人&#xff1a;zhangsan 指定标签名称&#xff1a;李四审批&#xff0c;节点任务负责人&#xf…

【稳定检索|投稿优惠】2024年公共服务、健康与医药国际会议(ICPSHM 2024)

2024年公共服务、健康与医药国际会议(ICPSHM 2024) 2024 International Conference on Public Services, Health, and Medicine(ICPSHM) 一、【会议简介】 ​2024年公共服务、健康与医药国际会议&#xff08;ICPSHM 2024&#xff09;将于三亚这片美丽的海滨城市盛大召开。我们诚…

【JAVA基础(对象和封装以及构造方法)】----第四天

对象和封装以及构造方法 面向对象和面向过程面向过程面向对象 类与对象及其使用定义类创建一个对象&#xff0c;操作类补充&#xff08;成员变量和局部变量&#xff09; private 修饰类 封装练习编写类编写测试输出结果 面向对象和面向过程 面向过程 在了解面向对象之前先来了…

线上BUG引起思考:package.json 中的 ^~ 该保留吗?

一、写在前面 一次线上项目 bug&#xff0c;引发了关于 package.json 中的 ^~ 是否该保留&#xff1f;保留可能引发的后果&#xff1f;以及如何在版本更新便利和版本更稳定中取舍的思考&#xff1f;这个 bug 是由于线上部署打包时&#xff0c;自己下载了最新依赖&#xff0c;于…

如何本地搭建Zblog网站并通过内网穿透将个人博客发布到公网

文章目录 1. 前言2. Z-blog网站搭建2.1 XAMPP环境设置2.2 Z-blog安装2.3 Z-blog网页测试2.4 Cpolar安装和注册 3. 本地网页发布3.1. Cpolar云端设置3.2 Cpolar本地设置 4. 公网访问测试5. 结语 正文开始前给大家推荐个网站&#xff0c;前些天发现了一个巨牛的 人工智能学习网站…

12.DHCP

DHCP 用户上网的时候&#xff0c;会从网卡发一个DHCP请求&#xff0c;是一个广播报文255.255.255.255&#xff0c;源地址是0.0.0.0 服务器得到请求后&#xff0c;返回给客户端一个地址 &#xff11;.在路由器开启DHCP功能 &#xff12;.配置地址池 3.指明给用户分配的网段…

制造企业MES管理系统可以和AI结合应用吗

在当今的数字化时代&#xff0c;人工智能AI和MES生产管理系统的结合将成为制造企业发展的重要趋势。这种结合可以为制造企业带来许多优势&#xff0c;如提高生产效率、降低成本、优化资源利用等。本文将探讨MES管理系统和AI的结合以及它们在制造企业中的应用&#xff0c;并分析…

Gateway网关-路由的过滤器配置

目录 一、路由过滤器 GatewayFilter 1.1 过滤器工厂GatewayFilterFactory 1.2 案例给所有进入userservice的请求添加一个请求头 Truthitcastis freaking awesome&#xff01; 1.3 案例给所有请求添加一个请求头 Truthitcastis freaking awesome&#xff01; 一、路由过滤器 …

鸿海携手Porotech共同开启Micro LED新篇章 | 百能云芯

近日&#xff0c;鸿海集团决定进一步强化其在Micro LED&#xff08;微发光二极体&#xff09;技术领域的实力。为此&#xff0c;鸿海宣布将与英国半导体企业Porotech展开战略合作&#xff0c;旨在共同开发MicroLED微显示器&#xff0c;并在AR&#xff08;扩增实境&#xff09;应…

Python学习之复习MySQL-Day8(事务)

目录 文章声明⭐⭐⭐让我们开始今天的学习吧&#xff01;事务简介事务操作模拟转账操作开启事务提交事务回滚事务查看/设置事务提交方法实例演示 事务四大特性并发事务问题分类 事务隔离级别分类查看/设置事务隔离级别实例演示 文章声明⭐⭐⭐ 该文章为我&#xff08;有编程语…

记录 | C++头文件中 <> 和 ““ 的区别

C 头文件中 <> 和 “” 的区别 #include <cstdio> #include "hello.h"int main(){printf("hello world!");return 0; }● <cstdio> 这种形式表示不要在当前目录下进行搜索&#xff0c;只在系统目录里搜索&#xff1b; ● "hello.h…

【网络安全】-Linux操作系统—操作系统发展历史与Linux

文章目录 操作系统发展历史初期的操作系统分时操作系统个人计算机操作系统 Linux的诞生UNIX与GNU项目Linux内核的创建 Linux的特点开放源代码多样性社区支持 Linux的应用服务器和超级计算机嵌入式系统桌面系统 总结 操作系统发展历史 操作系统&#xff08;Operating System&am…

Linux部署Nacos注册中心结合内网穿透实现远程访问UI管理界面

文章目录 1. Docker 运行Nacos2. 本地访问Nacos3. Linux安装Cpolar4. 配置Nacos UI界面公网地址5. 远程访问 Nacos UI界面6. 固定Nacos UI界面公网地址7. 固定地址访问Plik8. 结语 Nacos是阿里开放的一款中间件,也是一款服务注册中心&#xff0c;它主要提供三种功能&#xff1a…

电机驱动开发

最近在搞电机驱动程序&#xff0c;感觉很简单&#xff0c;实际操作却发现里面还有很多猫腻&#xff08;细节&#xff09;。 电机在嵌入式设备中非常常见&#xff0c;例如云台的转动&#xff0c;都是靠电机来驱动的。 电机常见分步进电机、直流电机&#xff0c;相对来说步进电机…

年度大盘点:AIGC、AGI、GhatGPT震撼登场!揭秘人工智能大模型的奥秘与必读书单

这里写目录标题 前言01 《ChatGPT 驱动软件开发》02 《ChatGPT原理与实战》03 《神经网络与深度学习》04 《AIGC重塑教育》05 《通用人工智能》 前言 在2023年&#xff0c;人工智能领域经历了一场前所未有的大爆发&#xff0c;特别是在语言模型领域。新的概念和英文缩写如AIGC、…

深度学习中的KL散度

1 KL散度概述 KL散度&#xff08;Kullback-Leibler Divergence&#xff09;&#xff0c;也称为相对熵&#xff0c;是信息论中的一个概念&#xff0c;用于衡量两个概率分布间的差异。它起源于统计学家Kullback和Leibler的工作&#xff0c;它的本质是衡量在用一个分布来近似另一…

轻松搭建FPGA开发环境:第三课——Vivado 库编译与设置说明

工欲善其事必先利其器&#xff0c;很多人想从事FPGA的开发&#xff0c;但是不知道如何下手。既要装这个软件&#xff0c;又要装那个软件&#xff0c;还要编译仿真库&#xff0c;网上的教程一大堆&#xff0c;不知道到底应该听谁的。所以很多人还没开始就被繁琐的开发环境搭建吓…