Mybatis Plus MySql json类型操作
SpringBoot 2.7.18 集成 Mybatis Plus + Druid
- 在数据库表定义json字段;
- 在实体类加上@TableName(autoResultMap = true)
- 在JSON字段映射的属性加上@TableField(typeHandler = JacksonTypeHandler.class);
条件查询
@Test
void jsonQueryWapperTest() {
String nickName = "李四";
String role = "普通用户22";
LambdaQueryChainWrapper<DemoInfo> queryWrapper = demoService.lambdaQuery();
queryWrapper.apply(StrUtil.isNotEmpty(role), "JSON_CONTAINS(roles,JSON_OBJECT('name', {0}))", role);
List<DemoInfo> list = queryWrapper.list();
System.out.println("Result => " + PojoUtil.pojoToJson(list));
}
MySqlJosnTypeHandler
@MappedTypes({Object.class})
@MappedJdbcTypes(JdbcType.VARCHAR)
public class MySqlJosnTypeHandler extends AbstractJsonTypeHandler<Object> {
public MySqlJosnTypeHandler(Class<?> type) {
super(type);
}
public MySqlJosnTypeHandler(Class<?> type, Field field) {
super(type, field);
}
@Override
public Object parse(String json) {
return JSON.parseObject(json, this.getFieldType());
}
@Override
public String toJson(Object obj) {
return JSON.toJSONString(obj);
}
}
本文来自博客园,作者:VipSoft 转载请注明原文链接:https://www.cnblogs.com/vipsoft/p/18529092
分类:
JAVA
标签:
SpringBoot
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
2013-11-05 [datatable]排序时指定某列不可排序