Spring Boot 3 集成 MyBatis详解

MyBatis是一款开源的持久层框架,它极大地简化了与数据库的交互流程。与类似Hibernate的ORM框架不同,MyBatis更具灵活性,允许开发者直接使用SQL语句与数据库进行交互。Spring Boot和MyBatis分别是两个功能强大的框架,它们的协同使用可以极大地简化数据访问层的开发,提高整体的开发效率。本文将详细介绍在Spring Boot项目中如何集成MyBatis,以实现对数据库的轻松访问和操作。

springboot3-mybatis.jpg

添加依赖

Spring Boot 3 发布后,Mybatis Starter相对应的mybatis-spring-boot-starter版本为3.x

xml 复制代码
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>3.0.3</version>
</dependency>

添加配置文件

常用的mybatis配置如下所示:

go 复制代码
mybatis:
  mapper-locations: classpath:mybatis/**/*Mapper.xml
  type-aliases-package: cn.xj.xjdoc.**.entity
  configuration:
    map-underscore-to-camel-case: true

参数说明:

  • mybatis.mapper-locations:指定MyBatis的Mapper XML文件的位置。
  • mybatis.type-aliases-package:指定MyBatis的类型别名包,即包含实体类的包路径,方便在xml配置文件中使用实体类时不用写包名。
  • mybatis.configuration.map-underscore-to-camel-case:开启或关闭驼峰命名法的自动映射功能。true表示开启,将数据库字段的下划线风格(例如,user_name)自动映射为Java实体类的驼峰命名风格(例如,userName)。

创建实体类和Mapper接口

创建一个实体类,表示数据库中的表,然后创建一个Mapper接口,用于定义数据库操作的方法。示例:

实体类SysUser:

typescript 复制代码
@Data
public class SysUser {
    private String userName;
    private String account;
}

Mapper接口SysUserMapper:

csharp 复制代码
@Mapper
public interface SysUserMapper {
    List<SysUser> listUser();
}

如果我们在启动类上使用了 @MapperScan 注解,就可以批量扫描 MyBatis 的 Mapper 接口所在的包,并将这些接口注册为 MyBatis 的映射器。在这种情况下,Mapper 接口本身就不再需要使用 @Mapper 注解来明确标识其为 MyBatis 的 Mapper 接口了。

less 复制代码
@SpringBootApplication
@MapperScan("cn.xj.xjdoc.**.mapper")
public class XjdocApplication {
 public static void main(String[] args) {
  SpringApplication.run(XjdocApplication.class, args);
 }

}

创建Mapper XML文件

xml 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.xj.xjdoc.system.mapper.SysUserMapper">

    <select id="listUser"  resultType="SysUser">
        select * from sys_user
    </select>
</mapper>

最后,运行你的Spring Boot应用程序,并确保没有错误发生。访问相关端点,测试数据库操作是否正常。

总结

总体而言,Spring Boot集成MyBatis为开发者提供了一套高效而又易于维护的数据库访问方案。通过合理的配置和良好的代码组织,我们能够快速搭建出健壮可靠的数据访问层,为整个应用的开发打下坚实基础。

相关推荐
召摇19 小时前
Spring Boot 内置工具类深度指南
java·spring boot
Moshow郑锴21 小时前
SpringBootCodeGenerator使用JSqlParser解析DDL CREATE SQL 语句
spring boot·后端·sql
小沈同学呀1 天前
创建一个Spring Boot Starter风格的Basic认证SDK
java·spring boot·后端
凤山老林1 天前
SpringBoot 轻量级一站式日志可视化与JVM监控
jvm·spring boot·后端
Chan161 天前
JVM从入门到实战:从字节码组成、类生命周期到双亲委派及打破双亲委派机制
java·jvm·spring boot·后端·intellij-idea
科兴第一吴彦祖1 天前
在线会议系统是一个基于Vue3 + Spring Boot的现代化在线会议管理平台,集成了视频会议、实时聊天、AI智能助手等多项先进技术。
java·vue.js·人工智能·spring boot·推荐算法
练习时长一年1 天前
搭建langchain4j+SpringBoot的Ai项目
java·spring boot·后端
Rysxt_1 天前
Spring Boot 集成 Spring AI OpenAI Starter 教程
java·spring boot·后端·ai
王道长服务器 | 亚马逊云2 天前
一个迁移案例:从传统 IDC 到 AWS 的真实对比
java·spring boot·git·云计算·github·dubbo·aws