Mybatis-扩展功能

逻辑删除+乐观锁

MyBatisPlus从入门到精通-3(含mp代码生成器)

Db静态工具类

Spring依赖循环问题

代码生成器

MybatisPlus代码生成器

枚举处理器

我们这里用int来存储状态

需要注解,很不灵活

希望用枚举类来代替这个Integer

这样的话我们进行service操作就可以直接看到信息

但是枚举类型和数据库中表的字段不匹配,怎么实现这个数据类型的转换呢?

mp实现了好用的枚举处理器和json处理器供我们使用

具体操作

创建注解和替换类型就不说了

1.enum中加@EnumValue注解

枚举类那个对应表的字段一定要包含数据库对应字段所以可能出现的情况

因为他是enum类型如果你查出个3他也没法创建啊,枚举类不给set,且构造方法是私有的

2.在配置文件写一个配置

这样写逻辑时候代码可读性就变的好一点

这样返回的是对象名啊,如果想设置别的作为返回的json数据的话,用@JsonValue标注

小声哔哔

我感觉常量类定义一下也可以这样

定义几个变量,就是要用英文标识呗,感觉用处不大

JSON处理器

我们查User表里面有个Userinfo的json属性

我们就用对象接收UserJson,需要json处理器

要不然只能有String 接收 info 自己处理

这时只需要加上@TableField(typeHandler = JacksonTypeHandler)注释

就是标定json处理器
我们json处理器不像枚举一样有全局配置,所以需要我们一个一个写注解喽

然后还要在@Tablename(autoResultMap = true)

开启resultmap映射

分页插件

分页插件最常用

这个是mp里面的功能哈


举例

封装VO返回就不看了

看一些怎么分页查吧

分页查询实体(所有业务分页查询都可以用它)

User扩展分页查询参数继承PageQuery

优化

其实上面的构建page

和封装VO的过程是每个分页查询都会做的

所以其实我们可以提取成工具方法


写完后改造之前业务逻辑

非常简洁

相关推荐
java1234_小锋16 分钟前
MyBatis如何处理懒加载和预加载?
java·开发语言·mybatis
绛洞花主敏明25 分钟前
Gorm(十四)的多条件叠加
数据库
枫叶丹41 小时前
【Qt开发】布局管理器(五)-> QSpacerItem 控件
开发语言·数据库·c++·qt
伯恩bourne1 小时前
【SqlServer】日志文件无法收缩的解决方法
数据库·oracle·sqlserver
星光一影1 小时前
SpringBoot+Vue3无人机AI巡检系统
人工智能·spring boot·websocket·mysql·intellij-idea·mybatis·无人机
像风一样自由20201 小时前
Redis与MinIO:两大存储利器的区别与联系
数据库·redis·缓存·minio
todoitbo2 小时前
使用n8n搭建服务器监控系统:从Webhook到Telegram告警的完整实现
运维·服务器·数据库·ai·向量数据库·流处理·n8n
only-code2 小时前
MCP驱动的Rgentic RRG(向量数据库+网络搜索)
数据库·python·大模型·函数调用·mcp
dongchen。3 小时前
MySQL第四次作业
数据库·mysql
普普通通的南瓜3 小时前
SM2 vs RSA/ECC:双算法 SSL 证书的性能对比与优化方案
数据库·网络协议·ssl