【BUG 记录】MyBatis-Plus 处理枚举字段和 JSON 字段
【BUG 记录】MyBatis-Plus 处理枚举字段和JSON字段
- 一、枚举字段(mysql环境已测、postgresql环境已测)
- 1.1 场景
- 1.2 定义枚举常量
- 1.3 配置枚举处理器
- 1.4 测试
- 二、JSON字段(mysql环境已测)
- 2.1 导包
- 2.2 使用对象接受
- 2.3 测试
- 三、JSON 字段 (postgresql环境 已测)
- 3.1 postgresql 数据库中的字段类型设置为 jsonb
- 3.2 创建实体类
- 3.3 创建 jsonb 类型处理器
- 3.3.1 方式一
- 3.3.2 方式二
- 3.4 测试
一、枚举字段(mysql环境已测、postgresql环境已测)
1.1 场景
在 User 实体类中有一个枚举字段(GenderEnum):
@Data
@TableName("test_user")
public class UserEntity {@TableId(value = "id", type = IdType.AUTO)private Integer id;private String name;private Integer age;private GenderEnum gender;private String address;private String phone;
}
像这种字段我们一般会定义一个枚举,做业务判断的时候就可以直接基于枚举做比较。但是我们数据库采用的是 int 类型,对应的 PO 也是Integer。因此业务操作时必须手动把枚举与 Integer 转换,非常麻烦。因此,Mybatis Plus提供了一个处理枚举的类型转换器,可以帮我们把枚举类型与数据库类型自动转换。
1.2 定义枚举常量
首先,我们为用户表中的这个状态字段定义一个枚举常量:
@Getter
public enum GenderEnum{WOMAN(0,"女"),MAN(1, "男");@EnumValueprivate final Integer code;@JsonValueprivate final String desc;GenderEnum(Integer code,String desc){this.code = code;this.desc = desc;}
}
要让
Mybatis Plus处理枚举与数据库类型自动转换,我们必须告诉Mybatis Plus,枚举中的哪个字段的值作为数据库值。Mybatis Plus提供了@EnumValue注解来标记枚举属性
并且,在
GenderEnum枚举中通过@JsonValue注解标记JSON序列化时展示的字段是desc
1.3 配置枚举处理器
在application.yml 文件中添加以下配置,以开启枚举处理器的功能:
mybatis-plus:configuration:default-enum-type-handler: com.baomidou.mybatisplus.core.handlers.MybatisEnumTypeHandler # 枚举处理器
1.4 测试
例如,根据id查询某个用户:
此时,查询出的User类的 status 字段会是枚举类型。

二、JSON字段(mysql环境已测)
2.1 导包
<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.79</version>
</dependency>
2.2 使用对象接受
@Data
@TableName(value= "test_user" ,autoResultMap = true)
public class UserEntity {@TableId(value = "id", type = IdType.AUTO)private Integer id;private String name;private Integer age;private GenderEnum gender;@TableField(typeHandler = FastjsonTypeHandler.class)private JSONObject address;private String phone;
}
注意:
- 添加
autoResultMap = true,开启自动映射 - 添加
@TableField(typeHandler = FastjsonTypeHandler.class),JSON处理器 - 字段类型修改为
JSONObject
2.3 测试


三、JSON 字段 (postgresql环境 已测)
3.1 postgresql 数据库中的字段类型设置为 jsonb

3.2 创建实体类
- 在实体类上加上
@TableName(value = "表名", autoResultMap = true) - 在
jsonb属性上加上@TableField(value = "字段", typeHandler = JsonbTypeHandler.class)
JsonbTypeHandler 这个类在下面创建
@Data
@TableName(value= "test_user" ,autoResultMap = true)
public class UserEntity {@TableId(value = "id", type = IdType.AUTO)private Integer id;private String name;private Integer age;private GenderEnum gender;@TableField(value = "address", typeHandler = JsonbTypeHandler.class)private Object address;private String phone;
}
3.3 创建 jsonb 类型处理器
3.3.1 方式一
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.baomidou.mybatisplus.extension.handlers.AbstractJsonTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedJdbcTypes;
import org.apache.ibatis.type.MappedTypes;
import org.postgresql.util.PGobject;import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Objects;@MappedTypes({Object.class})
@MappedJdbcTypes({JdbcType.VARCHAR})
public class JsonbTypeHandler extends AbstractJsonTypeHandler<Object> {private static final PGobject jsonObject = new PGobject();private final Class<?> type;public JsonbTypeHandler(Class<?> type) {this.type = type;}/*** 重写设置参数* @param ps* @param i* @param parameter* @param jdbcType* @throws SQLException*/@Overridepublic void setNonNullParameter(PreparedStatement ps, int i, Object parameter, JdbcType jdbcType) throws SQLException {if (ps != null) {jsonObject.setType("jsonb");jsonObject.setValue(JSON.toJSONString(parameter));ps.setObject(i, jsonObject);}}/*** 根据列名,获取可以为空的结果* @param rs* @param columnName* @return* @throws SQLException*/@Overridepublic Object getNullableResult(ResultSet rs, String columnName) throws SQLException {Object v = rs.getObject(columnName);return toFill(v);}/*** 根据列索引,获取可以为空的结果* @param rs* @param columnIndex* @return* @throws SQLException*/@Overridepublic Object getNullableResult(ResultSet rs, int columnIndex) throws SQLException {Object v = rs.getObject(columnIndex);return toFill(v);}@Overridepublic Object getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {Object v = cs.getObject(columnIndex);return toFill(v);}@Overrideprotected Object parse(String json) {return JSON.parseObject(json, this.type);}/*** 必须将 v 转成 PGObject 处理* @param v* @return*/private Object toFill(Object v) {if (v != null && v instanceof PGobject) {PGobject p = (PGobject) v;String pv = p.getValue();if (Objects.nonNull(pv) && ("jsonb".equals(p.getType()) || "json".equals(p.getType()))) {return parse(p.getValue());}}return v;}@Overrideprotected String toJson(Object obj) {return JSON.toJSONString(obj, SerializerFeature.WriteMapNullValue, SerializerFeature.WriteNullListAsEmpty, SerializerFeature.WriteNullStringAsEmpty);}
}
3.3.2 方式二
package com.xawl.webenum.handler;import com.alibaba.fastjson.JSON;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedTypes;
import org.postgresql.util.PGobject;import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;@MappedTypes({Object.class})
public class JsonbDataTypeHandler extends BaseTypeHandler<Object> {private static final PGobject jsonObject = new PGobject();@Overridepublic void setNonNullParameter(PreparedStatement preparedStatement, int i, Object o, JdbcType jdbcType) throws SQLException {if (preparedStatement != null) {jsonObject.setType("jsonb");jsonObject.setValue(JSON.toJSONString(o));preparedStatement.setObject(i, jsonObject);}}@Overridepublic Object getNullableResult(ResultSet resultSet, String s) throws SQLException {return JSON.parse(resultSet.getString(s));}@Overridepublic Object getNullableResult(ResultSet resultSet, int i) throws SQLException {return JSON.parse(resultSet.getString(i));}@Overridepublic Object getNullableResult(CallableStatement callableStatement, int i) throws SQLException {return JSON.parse(callableStatement.getString(i));}
}
3.4 测试
- 测试 save
插入成功

- 测试 get

相关文章:
【BUG 记录】MyBatis-Plus 处理枚举字段和 JSON 字段
【BUG 记录】MyBatis-Plus 处理枚举字段和JSON字段 一、枚举字段(mysql环境已测、postgresql环境已测)1.1 场景1.2 定义枚举常量1.3 配置枚举处理器1.4 测试 二、JSON字段(mysql环境已测)2.1 导包2.2 使用对象接受2.3 测试 三、JS…...
Web性能优化-详细讲解与实用方法-MDN文档学习笔记
Web性能优化 查看更多学习笔记:GitHub:LoveEmiliaForever MDN中文官网 性能优良的网站能够提高访问者留存和用户满意度,减少客户端和服务器之间传输的数据量可降低各方的成本 不同的业务目标和用户需求需要不同的性能度量,要提高…...
组态王连接施耐德M580PLC
组态王连接施耐德M580 网络架构 网线连接PLC和装组态王软件的PC组态设置帮助 可先查看帮助:菜单栏点击【帮助】->【驱动帮助】,在弹出窗口中PLC系列选择莫迪康PLC的“modbusRtu\ASSCII\TCP”查看组态配置流程: 相关说明: 1、…...
pop链构造 [NISACTF 2022]babyserialize
打开题目 题目源代码如下 <?php include "waf.php"; class NISA{public $fun"show_me_flag";public $txw4ever;public function __wakeup(){if($this->fun"show_me_flag"){hint();}}function __call($from,$val){$this->fun$val[0];…...
【VIP专属】Python应用案例——基于Keras, OpenCV和MobileNet口罩佩戴识别
目录 1、导入所需库 2、加载人脸口罩检测数据集 3、对标签进行独热编码...
Doris——荔枝微课统一实时数仓建设实践
目录 一、业务介绍 二、早期架构及痛点 2.1 早期架构 2.2 架构痛点 三、技术选型 四、新的架构及方案 五、搭建经验 5.1 数据建模 5.2 数据开发 5.3 库表设计 5.4 数据管理 5.4.1 监控告警 5.4.2 数据备份与恢复 六、收益总结 七、未来规划 原文大佬这篇Doris腾…...
Stable Diffusion 绘画入门教程(webui)-ControlNet(Inpaint)
上篇文章介绍了语义分割Tile/Blur,这篇文章介绍下Inpaint(重绘) Inpaint类似于图生图的局部重绘,但是Inpain效果要更好一点,和原图融合会更加融洽,下面是案例,可以看下效果(左侧原图…...
LeetCode146: LRU缓存
题目描述 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存 int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则…...
【ArcGIS】基于DEM/LUCC等数据统计得到各集水区流域特征
基于DEM/LUCC等数据统计得到各集水区流域特征 提取不同集水区各类土地利用类型比例步骤1:划分集水区为独立面单元步骤2:批量掩膜提取得到各集水区土地利用类型比例步骤3:导入各集水区LUCC数据并统计得到各类型占比 提取坡度特征流域面坡度河道…...
vue3中安装并使用CSS预处理器Sass的方法介绍
文章目录 Sass是什么?为什么使用Sass?安装sass1、安装sass2、编写全局css变量/全局mixin3、vite引入并使用4、按需引入并使用 sass语法1、变量创建一个变量使用变量变量作用域 2、数学计算两个Sass有关于数学计算的“陷阱” 3、嵌套4、Imports sass中文官网 Sass是…...
过滤器(Filter)
过滤器(Filter) 1. 基本概念 过滤器(Filter)是拦截 Request 请求的对象:在用户的请求访问资源前处理 ServletRequest 和 ServletResponse 。 Filter 相关的接口有:Filter、FilterConfig、FilterChain 。…...
AMRT3D数字孪生引擎详解
AMRT 3D数字孪生引擎介绍 AMRT3D引擎是一款融合了眸瑞科技的AMRT格式与轻量化处理技术为基础,以降本增效为目标,支持多端发布的一站式纯国产自研的CS架构项目开发引擎。 引擎包括场景搭建、UI拼搭、零代码交互事件、光影特效组件、GIS/BIM组件、实时数据…...
Sqlite数据库详解
1.关于Sqlite SQLite 是一个进程内库,它实现了一个独立的、无服务器的、零配置的事务性 SQL 数据库引擎。 SQLite的代码属于公共领域,因此对 用于任何目的,商业或私人目的。 SQLite是世界上部署最广泛的数据库 应用程序比我们能做的要多 计数…...
基于YOLOv8深度学习+Pyqt5的电动车头盔佩戴检测系统
wx供重浩:创享日记 对话框发送:225头盔 获取完整源码源文件已标注的数据集(1463张)源码各文件说明配置跑通说明文档 若需要一对一远程操作在你电脑跑通,有偿59yuan 效果展示 基于YOLOv8深度学习PyQT5的电动车头盔佩戴检…...
【数据结构】B树,B+树,B*树
文章目录 一、B树1.B树的定义2.B树的插入3.B树的中序遍历 二、B树和B*树1.B树的定义2.B树的插入3.B*树的定义4.B树系列总结 三、B树与B树的应用 一、B树 1.B树的定义 1. 在内存中搜索效率高的数据结构有AVL树,红黑树,哈希表等,但这是在内存…...
常用实验室器皿耐硝酸盐酸进口PFA材质容量瓶螺纹盖密封效果好
PFA容量瓶规格参考:10ml、25ml、50ml、100ml、250ml、500ml、1000ml。 别名可溶性聚四氟乙烯容量瓶、特氟龙容量瓶。常用于ICP-MS、ICP-OES等痕量分析以及同位素分析等实验,也可在地质、电子化学品、半导体分析测试、疾控中心、制药厂、环境检测中心等机…...
【kubernetes】二进制部署k8s集群之cni网络插件flannel和calico工作原理
k8s集群的三种接口 k8s集群有三大接口: CRI:容器进行时接口,连接容器引擎--docker、containerd、cri-o、podman CNI:容器网络接口,用于连接网络插件如:flannel、calico、cilium CSI:容器存储…...
Pycharm一直打不开,无任何报错
我windows安装了pycharm一直打不开(无论专业版还是社区版都打不开),无任何弹窗,无任何报错 最后解决问题: 查看环境变量PYCHARM_VM_OPTIONS 发现有一个环境变量PYCHARM_VM_OPTIONS 删除PYCHARM_VM_OPTIONS这个环境变量,pycharm终…...
用html编写的小广告板
用html编写的小广告板 相关代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</tit…...
hive中如何取交集并集和差集
交集 要获取两个表的交集,你可以使用INNER JOIN或者JOIN: SELECT * FROM table1 JOIN table2 ON table1.column_name table2.column_name;也可以使用 INTERSECT 关键字 SELECT * FROM table1 INTERSECT SELECT * FROM table2;并集 要获取两个表的并集…...
小米路由器WiFi下电脑互ping失败?别急着换设备,先检查这个隐藏的加密设置
小米路由器局域网设备互访失败?可能是加密协议在"作怪" 家里用小米路由器的朋友,有没有遇到过这样的场景:明明所有设备都连着同一个WiFi,电脑却死活ping不通NAS,手机看不到电视的投屏选项,游戏联…...
如何免费下载Steam创意工坊模组:WorkshopDL完整使用指南
如何免费下载Steam创意工坊模组:WorkshopDL完整使用指南 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 你是否在Epic Games Store或GOG等平台购买了游戏࿰…...
RISC-V架构——物理内存保护(PMP)实战:从配置寄存器到安全区域设定
1. 初识RISC-V PMP:为什么需要物理内存保护? 第一次接触RISC-V的物理内存保护(PMP)功能时,我正为一个嵌入式项目调试内存越界问题。当时应用程序意外改写了关键配置区,导致系统崩溃。这种"手滑"操…...
别再手动洗数据了!用Datatrove Pipeline把FastText分类和关键词过滤自动化
从零构建自动化数据清洗流水线:基于Datatrove与FastText的工程实践 在机器学习项目的生命周期中,数据清洗往往占据70%以上的时间成本。传统的手工处理方式不仅效率低下,更难以应对TB级数据的规模化挑战。本文将分享如何利用Datatrove框架与Fa…...
STP/RSTP/MSTP到底怎么选?一张图讲清华为/思科交换机防环协议演进与配置差异
STP/RSTP/MSTP技术选型指南:从协议原理到厂商配置实战 在网络架构设计中,环路预防是保障业务连续性的基石。当工程师面对STP、RSTP和MSTP三大生成树协议时,如何根据网络规模、业务需求和设备特性做出合理选择?本文将深入解析协议演…...
别再被‘NoneType‘坑了!Python新手必看的5个实战避坑技巧(附代码)
别再被NoneType坑了!Python新手必看的5个实战避坑技巧(附代码) 刚学会用Python写爬虫的小张,兴奋地运行了自己写的第一个爬虫脚本,结果屏幕上赫然出现了一行刺眼的错误提示:TypeError: NoneType object is …...
第三章 低通滤波(LPF)
一 应用场景及公式当负载设备VCC需要的电压是1V,但是我们有12V的电压时,就需要使用电阻分压。问题:非理想环境中12V的电压会有波动(噪声)的,故而分出来1V电压也是有噪声的。1.1 容抗公式 :容抗(…...
基于鸿蒙Electron框架的物体碰撞效果测试应用开发详解
欢迎加入开源鸿蒙PC社区: https://harmonypc.csdn.net/ atomgit开源仓库地址: https://atomgit.com/feng8403000/game_Collisioneffect 示例效果 基于鸿蒙Electron框架的物体碰撞效果测试应用开发详解示例效果技术栈选择前端技术后端技术技术优势应用功…...
从Modbus到蓝牙:一文搞懂CRC16在常见通信协议里的‘潜规则’与C语言实战
从Modbus到蓝牙:一文搞懂CRC16在常见通信协议里的‘潜规则’与C语言实战 第一次调试Modbus RTU设备时,我盯着示波器上规整的波形却始终收不到正确响应,直到发现CRC校验码的初始值设成了0xFFFF而不是协议要求的0x0000——这个细节让我意识到&a…...
real-anime-z应用场景:动漫社团微信公众号推文配图自动化生成流程
real-anime-z应用场景:动漫社团微信公众号推文配图自动化生成流程 1. 引言:动漫社团的配图痛点 运营动漫社团微信公众号的小伙伴们,是否经常遇到这样的困扰: 每周需要制作大量推文配图,但社团美编人手有限原创插画成…...
