news 2026/4/27 17:42:25

MyBatis-Plus 快速入门与常用注解、配置总结(黑马springcloud微服务课程)(day1)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MyBatis-Plus 快速入门与常用注解、配置总结(黑马springcloud微服务课程)(day1)

MyBatis-Plus 快速入门与核心用法总结

📚 目录(点击跳转对应章节)

一、前言
二、环境准备
三、MyBatis-Plus 快速开始
四、MyBatis-Plus 核心原理
五、常用注解详解
六、MyBatis-Plus 常用配置
七、手写 SQL 支持
八、总结


一、前言

在日常开发中,单表 CRUD 是最常见、也是最重复的工作。

MyBatis 虽然灵活,但通常需要编写大量 Mapper XML 或注解 SQL,开发效率较低。

MyBatis-Plus(简称 MP)是在 MyBatis 基础上的增强框架,提供了通用 CRUD 能力,在不影响原有功能的前提下,大幅减少样板代码,提高开发效率。

本文将从以下几个方面对 MyBatis-Plus 的核心用法进行总结:

  • 环境准备
  • 快速入门
  • 核心原理
  • 常用注解
  • 常用配置
  • 手写 SQL 支持

二、环境准备

数据源配置

application.yaml中配置数据库连接信息:

spring:datasource:url:jdbc:mysql://127.0.0.1:3306/mp?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghaidriver-class-name:com.mysql.cj.jdbc.Driverusername:rootpassword:MySQL123logging:level:com.itheima:debugpattern:dateformat:HH:mm:ss

三、MyBatis-Plus 快速开始

1. 引入依赖

MyBatis-Plus 提供了官方 Starter,已集成 MyBatis 自动装配功能,可直接替换 MyBatis Starter。

<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.3.1</version></dependency>

完整依赖示例如下:

<dependencies><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.3.1</version></dependency><dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies>

2. 定义 Mapper

MyBatis-Plus 提供了通用接口BaseMapper<T>,内置了常见的单表 CRUD 方法。

自定义 Mapper 只需继承BaseMapper

packagecom.itheima.mp.mapper;importcom.baomidou.mybatisplus.core.mapper.BaseMapper;importcom.itheima.mp.domain.po.User;publicinterfaceUserMapperextendsBaseMapper<User>{}

无需编写 XML 或 SQL,即可直接使用通用 CRUD 方法。


3. CRUD 操作说明

MyBatis-Plus 提供的常用 CRUD 方法包括:

  • insert:插入数据
  • selectById:根据 ID 查询
  • selectBatchIds:批量查询
  • updateById:根据 ID 更新
  • deleteById:根据 ID 删除

上述方法均由 MyBatis-Plus 自动实现,可直接调用,显著减少 XML 编写。


四、MyBatis-Plus 核心原理

MyBatis-Plus 通过实体类(PO)推断数据库表结构,默认遵循以下约定:

  • 实体类名(驼峰)映射为表名(下划线)
  • 实体属性名(驼峰)映射为字段名(下划线)
  • 名为id的属性默认作为主键

在实际项目中,若数据库设计不完全符合约定规则,可通过注解进行精确映射。


五、常用注解详解

1. @TableName

作用:指定实体类对应的数据库表名
使用位置:实体类

@TableName("user")publicclassUser{privateLongid;}

常用属性:

  • value:表名
  • schema:数据库 schema
  • autoResultMap:是否自动构建 ResultMap
  • excludeProperty:排除字段

2. @TableId

作用:指定主键字段
使用位置:实体类主键属性

@TableId(type=IdType.AUTO)privateLongid;

常见主键策略:

  • AUTO:数据库自增
  • INPUT:手动设置
  • ASSIGN_ID:雪花算法生成 Long 类型主键(默认)

3. @TableField

作用:声明普通字段映射关系

常见使用场景:

  • 属性名与字段名不一致
  • isXXX命名的布尔字段
  • 字段名是数据库关键字
  • 实体中存在非表字段

示例:

@TableField("is_married")privateBooleanmarried;@TableField(exist=false)privateStringextraInfo;

六、MyBatis-Plus 常用配置

1. 全局配置

mybatis-plus:type-aliases-package:com.itheima.mp.domain.poglobal-config:db-config:id-type:auto

配置说明:

  • type-aliases-package:实体类别名扫描路径
  • id-type:全局主键策略

2. Mapper XML 扫描路径

MyBatis-Plus 支持手写 SQL,默认 XML 扫描路径如下:

mybatis-plus:mapper-locations:classpath*:/mapper/**/*.xml

七、手写 SQL 支持

mapper目录下创建UserMapper.xml

<mappernamespace="com.itheima.mp.mapper.UserMapper"><selectid="queryById"resultType="User">SELECT * FROM user WHERE id = #{id}</select></mapper>

UserMapper接口中声明对应方法,即可与 MyBatis-Plus 自动 CRUD 方法混合使用。


八、总结

MyBatis-Plus 在不破坏 MyBatis 原有特性的前提下,提供了高效、简洁的单表操作能力,包括:

  • 通用 CRUD 自动实现
  • 灵活的注解配置
  • 合理的默认约定
  • 对 XML 与手写 SQL 的完全兼容

在实际开发中,大多数单表操作可以直接通过 MyBatis-Plus 完成,能够显著减少重复代码,提高整体开发效率。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 1:36:51

HS2-HF Patch增强工具:插件集成与性能优化指南

HS2-HF Patch增强工具&#xff1a;插件集成与性能优化指南 【免费下载链接】HS2-HF_Patch Automatically translate, uncensor and update HoneySelect2! 项目地址: https://gitcode.com/gh_mirrors/hs/HS2-HF_Patch HS2-HF Patch作为Honey Select 2的插件集成解决方案&…

作者头像 李华
网站建设 2026/4/23 15:26:43

Bebas Neue字体设计与应用全解析:从几何构想到商业实践

Bebas Neue字体设计与应用全解析&#xff1a;从几何构想到商业实践 【免费下载链接】Bebas-Neue Bebas Neue font 项目地址: https://gitcode.com/gh_mirrors/be/Bebas-Neue 一、字体起源与设计理念 1.1 设计哲学的形成与演进 Bebas Neue字体家族的设计理念根植于现代…

作者头像 李华
网站建设 2026/4/22 4:19:12

掌握Poppins:30分钟精通现代几何字体的高效应用指南

掌握Poppins&#xff1a;30分钟精通现代几何字体的高效应用指南 【免费下载链接】Poppins Poppins, a Devanagari Latin family for Google Fonts. 项目地址: https://gitcode.com/gh_mirrors/po/Poppins Poppins是一款由Indian Type Foundry精心打造的现代几何无衬线字…

作者头像 李华
网站建设 2026/4/23 15:39:30

三极管开关电路实现PLC信号隔离:从零实现方案

以下是对您提供的技术博文进行 深度润色与结构重构后的专业级技术文章 。整体遵循“去AI化、强工程感、重实操性、逻辑自洽、语言鲜活”的原则&#xff0c;彻底摒弃模板式表达和空泛总结&#xff0c;以一位深耕工业控制一线十年的嵌入式系统工程师口吻娓娓道来——既有原理推…

作者头像 李华
网站建设 2026/4/23 18:49:16

抖音批量下载高效工具解决方案:从入门到精通

抖音批量下载高效工具解决方案&#xff1a;从入门到精通 【免费下载链接】douyin-downloader 项目地址: https://gitcode.com/GitHub_Trending/do/douyin-downloader 你是否曾遇到这样的困境&#xff1a;花3小时手动下载20个视频却发现都带水印&#xff1f;尝试批量保存…

作者头像 李华
网站建设 2026/4/23 18:56:29

颠覆式游戏数据解析:ROFL-Player全方位回放分析解决方案

颠覆式游戏数据解析&#xff1a;ROFL-Player全方位回放分析解决方案 【免费下载链接】ROFL-Player (No longer supported) One stop shop utility for viewing League of Legends replays! 项目地址: https://gitcode.com/gh_mirrors/ro/ROFL-Player 在电子竞技数据分析…

作者头像 李华