Mybatis Plus MySql json类型操作

SpringBoot 2.7.18 集成 Mybatis Plus + Druid

  1. 在数据库表定义json字段;
  2. 在实体类加上@TableName(autoResultMap = true)
  3. 在JSON字段映射的属性加上@TableField(typeHandler = JacksonTypeHandler.class);
    image
    image

条件查询

@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);
    }

}

posted @   VipSoft  阅读(34)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
历史上的今天:
2013-11-05 [datatable]排序时指定某列不可排序
点击右上角即可分享
微信分享提示