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
 
                    
                 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号