MyBatisPlus笔记01 CRUD
data:image/s3,"s3://crabby-images/79f28/79f28d247821637f6f4ac208a4f5c3e3f09c5b22" alt=""
https://www.bilibili.com/video/BV1rE41197jR
p1~25
数据库准备
1 | -- 创建测试表 |
创建工程
导入依赖
1 | <dependencies> |
配置文件
log4j.properties
1 | DEBUG,A1 = |
application.properties
1 | itcast-mp-springboot = |
实体类
使用lombok注解生成get、set方法
使用MybatisPlus注解指定表名
1 | package com.coconutnut.demo.pojo; |
用@TableId指定id的增长策略
@TableField
可解决的问题:
对象中的属性名和字段名不一致的问题(非驼峰)
1
2
private String mail;对象中的属性字段在表中不存在的问题
1
2
private String address;查询时不返回该字段的值
1
2
private String password;
Mapper接口
1 | package com.coconutnut.demo.mapper; |
SpringBoot启动类
使用@MapperScan设置mapper接口的扫描包
1 | package com.coconutnut.demo; |
项目结构
data:image/s3,"s3://crabby-images/a53a3/a53a391801265181ff5ac4c8b5d873f3839fb5fc" alt=""
测试
1 | package com.coconutnut.demo; |
输出
data:image/s3,"s3://crabby-images/ed3bc/ed3bc381c4881e79a6a89e8d16a3555181c8c0ae" alt=""
DEBUG 依赖重复
1 | SLF4J: Class path contains multiple SLF4J bindings. |
删除依赖中的
1 | <dependency> |
CRUD
查看UserMapper继承的BaseMapper源码
data:image/s3,"s3://crabby-images/ea48e/ea48efbc237529d5f6f4a4a24ebae078fbada088" alt=""
CRUD方法都有了
官网文档
https://mybatis.plus/guide/crud-interface.html#mapper-crud-%E6%8E%A5%E5%8F%A3
直接测试
插入
1 | // 插入一条记录 |
1 | package com.coconutnut.demo; |
运行后,数据库变化
data:image/s3,"s3://crabby-images/3b8a8/3b8a888c15ed7ca611246f7ef6aa917c28220ee8" alt=""
输出
data:image/s3,"s3://crabby-images/d2834/d28344e0d758fb7ade874b49896400828e4756c2" alt=""
更新
1 | // 根据 whereEntity 条件,更新记录 |
根据id更新
1 |
|
执行后
data:image/s3,"s3://crabby-images/fad24/fad241f54c1fcc20ed62dea33c3d5b722fbd37c4" alt=""
根据条件更新
QueryWrapper
1 |
|
wrapper中设置属性用的是mysql表中的名称
执行后
data:image/s3,"s3://crabby-images/11158/11158d39894a2a6e8d84b66dc76e0a22f51a5ffb" alt=""
UpdateWrapper
1 |
|
执行后
data:image/s3,"s3://crabby-images/a67d6/a67d6e514822b14b1078a38fba6ea2d2882dec20" alt=""
删除
1 | // 根据 entity 条件,删除记录 |
deleteById
1 |
|
执行后
data:image/s3,"s3://crabby-images/62d46/62d466a685d63a1c846ae1a790d1d5503a7fd0d6" alt=""
deleteByMap
1 |
|
执行后
data:image/s3,"s3://crabby-images/78dad/78dadffb54adac0cadcabc88178e1c6a35267e23" alt=""
没有符合条件的
delete
1 |
|
推荐使用用法2
deleteByIds
1 |
|
查询
1 | // 根据 ID 查询 |
selectById
1 |
|
执行后
data:image/s3,"s3://crabby-images/628b4/628b4a3133f5d33c16eb73f70a3c8237ad681704" alt=""
没查到为null
selectOne
不存在返回null
查到多条报错
1 |
|
输出
1 | User(id=2, userName=lisi, password=123456, name=李四, age=20, email=test2@itcast.cn) |
selectBatchIds
1 |
|
执行后
data:image/s3,"s3://crabby-images/c3d1a/c3d1aa1bdc48af779181e32cf2219a35781cb730" alt=""
selectCount
1 |
|
输出
1 | count = 2 |
selectList
1 |
|
执行后
data:image/s3,"s3://crabby-images/b9e79/b9e794d9ddfd510637a4ffb9fdee2152b656b04b" alt=""
selectPage
配置分页插件
1 | import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor; |
有了这个配置类之后,DemoApplication中的@MapperScan可以去掉
1 |
|
执行后
data:image/s3,"s3://crabby-images/f33a8/f33a8613fb5d86ff6696e585a63bad8e24fae038" alt=""