MyBatis-Plus 使用

MyBatis-Plus 🚀 为简化开发而生

1. 快速上手

1.1 准备工作

1.2 编码

创建实体类 UserInfo

编写Mapper接口类

MyBatisPlus提供了一个基础的BaseMapper接口,已经实现了单标的CRUD,我们自定义的Mapper只需要继承这个BaseMapper,无需自己实现单表CRUD

1.3 CRUD测试

2. Mybatis-Plus 复杂操作

2.1 常见注解

Mybatis是如何知道要操作那张表,表中的哪些字段

UserInfoMapper 在继承 BaseMapper 时指定了一个泛型,这个UserInfo就是与数据表相对应的实体类

Mybatis-Plus 会根据这个实体类来推断表的信息

默认情况如下:

  1. 表名

  2. 字段

  3. 主键:默认是id

2.1.1 @TableName

可以通过@TableName来表示实体类对应的表

2.1.2 @TableField

2.1.3 @Tabled

2.2 条件构造器

入门程序里的使用,都是简单的CRUD,在实际的应用场景中,我们还需要使用更复杂的操作,Mybatis-Plus 也提供了相应的支持

Mybatis-Plus 提供了一套强大的条件构造器(Wrapper)用于构建复杂的查询条件条件构造器 | MyBatis-Plus

2.2.1 QueryWrapper

QueryWrapper并不只是用于查询语句,无论是修改、删除、查询都可以使用QueryWrapper来构建查询条件

查询

复制代码
SELECT id,username,password,age FROM user_info WHERE age = 18 AND username 
like "%min%"

更新

复制代码
UPDATE user_info SET delete_flag=? WHERE age < 20

删除

复制代码
DELETE FROM user_info WHERE age = 4

2.2.2 UpdateWrapper

对于更新,我们可以直接使用 UpdateWrapper ,在不创建实体对象的情况下,直接设置更新字段和条件

复制代码
UPDATE user_info SET delete_flag=0, age=5 WHERE id IN (1,2,3)

2.2.3 LamdbaQueryWrapper

QueryWrapper 和 UpdateWrapper 都存在一个问题,就是需要写死字段名,如果字段名发生变更,可能会因为测试不到位造成错误

Mybatis-Plus 提供了一种基于Lambda表达式的条件和构造器,它通过Lambda 表达式引用实体类属性,从而避免了硬编码字段名,也提高了代码的可读性和可维护性

2.2.4 LambdaUpdateWrapper

2.3 自定义SQL

在实际开发中,Mybatis-Plus提供的操作不能满足实际需求,Mybatis-Plus 也提供了自定义SQL功能,我们可以利用Wrapper构造查询条件,再结合Mapper编写SQL

相关推荐
是宇写的啊17 小时前
博客系统-小项目
java·数据库·spring boot·mybatis
月落归舟1 天前
MyBatis缓存机制
java·缓存·mybatis
段ヤシ.1 天前
回顾Java知识点,面试题汇总Day12(持续更新)
java·mybatis
XS0301061 天前
MyBatis动态SQL
数据库·sql·mybatis
MandalaO_O1 天前
MyBatis 与 MySQL 执行流程
数据库·mysql·mybatis
今天也是元气满满的一天呢2 天前
7篇文章学会MyBatis——第一篇:部署及基本概念
mybatis
Simon523142 天前
mybatis执行流程、关联映射、注解开发
java·开发语言·mybatis
happymaker06262 天前
SpringBoot学习日记——DAY05(SpringBoot整合MyBatis-plus实现增删改查)
spring boot·学习·mybatis
北风toto3 天前
通过Entity 创建数据库中的表,目前只支持mysql,A.CTable使用mybatis/mybatis-plus自动创建表
数据库·mysql·mybatis