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的过程是每个分页查询都会做的

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


写完后改造之前业务逻辑

非常简洁

相关推荐
bing_1583 小时前
跨多个微服务使用 Redis 共享数据时,如何管理数据一致性?
redis·微服务·mybatis
寒山李白4 小时前
MySQL安装与配置详细讲解
数据库·mysql·配置安装
文牧之4 小时前
PostgreSQL 的扩展pg_freespacemap
运维·数据库·postgresql
deriva5 小时前
某水表量每15分钟一报,然后某天示数清0了,重新报示值了 ,如何写sql 计算每日水量
数据库·sql
Leo.yuan6 小时前
数据库同步是什么意思?数据库架构有哪些?
大数据·数据库·oracle·数据分析·数据库架构
Kookoos6 小时前
ABP VNext 与 Neo4j:构建基于图数据库的高效关系查询
数据库·c#·.net·neo4j·abp vnext
云之兕6 小时前
MyBatis 的动态 SQL
数据库·sql·mybatis
gaoliheng0066 小时前
Redis看门狗机制
java·数据库·redis
?ccc?7 小时前
MySQL主从复制与读写分离
数据库·mysql
会飞的Anthony7 小时前
数据库优化实战分享:高频场景下的性能调优技巧与案例解析
数据库