java 实体属性 Map 解决 mybatis-plus wrapper selectone 查mysql json类型为null 问题

mysql 有个字段是json类型

bash 复制代码
  `content_map` json DEFAULT NULL COMMENT '个性化配置内容(LAN3/BGP等)',

java 实体属性

bash 复制代码
    /**
     * 个性化配置内容(JSON存储,包含LAN3/BGP等)
     */
    @TableField(value = "content_map", typeHandler = com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler.class)
    private Map<String, Object> contentMap;

mybatis-plus 使用wrapper

bash 复制代码
        LambdaQueryWrapper<xxxx> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(xxx::getId, id)
                .eq(xxx::getStoreCode, storeCode);

        // 2. 查询现有记录
       xxx xx= xxx.getOne(queryWrapper);

但是问题是:content_map 查不到数据,用原生的mybatis 可以正常使用

原因:
MyBatis-Plus 的 JacksonTypeHandler(以及大多数自定义 TypeHandler)默认是按字符串(String)来处理 JSON 的。
但 MySQL 的 JSON 类型在 JDBC 驱动中返回的是 java.sql.SQLJSON 对象(或内部以二进制/特殊格式存储),不是 String!
JDBC 返回 SQLJSON,JacksonTypeHandler 调 getString() 可能失败 → 改用 TEXT

AI和 网上建议加上

bash 复制代码
@MappedJdbcTypes(JdbcType.OTHER) // MySQL JSON 类型映射为 JdbcType.OTHER
@MappedTypes(Map.class)
public class MySqlJsonTypeHandler extends BaseTypeHandler<Map<String, Object>> {

改xml文件

bash 复制代码
   <result property="contentMap" column="content_map"
            typeHandler="com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler"/>

都没有生效

为什么?

因为wrapper 无法利用 MyBatis-Plus 的 JacksonTypeHandler 自动映射

如果你用 String 类型,即使加了 @TableField(typeHandler = JacksonTypeHandler.class),它也会尝试把 Java 对象序列化成 JSON 字符串,但目标字段是 String,可能导致类型不匹配或异常。

解决方案:

bash 复制代码
@TableName(value= "xxx",autoResultMap = true)

让 MP 自动生成带 typeHandler 的 resultMap

@TableName(autoResultMap = true) 是 MyBatis-Plus(MP) 提供的一个非常关键的注解属性,用于自动为实体类生成内联的 resultMap,从而支持如 typeHandler、association、collection 等复杂映射功能。

后面可以试一下这样

相关推荐
swordbob2 分钟前
缓存延迟双删的两种策略
java·缓存
凡人叶枫2 分钟前
Effective C++ 条款08:别让异常逃离析构函数
java·linux·数据库·c++·嵌入式开发
云烟成雨TD3 分钟前
Agent Scope Java 2.x 系列【4】模型层
java·人工智能·agent
云烟成雨TD15 分钟前
Agent Scope Java 2.x 系列【5】智能体抽象层
java·人工智能·agent
阿伟AI说19 分钟前
Codex 桌面版接入国产模型系列二:Codex++
java·开源软件·ai编程·腾讯云ai代码助手
love_muming40 分钟前
链表每日一练
java·开发语言·数据结构·链表·idea·每日一练
范什么特西43 分钟前
重点:mybatis注意细节
java·mysql·mybatis
乐观勇敢坚强的老彭1 小时前
GESP一级核心算法:循环与条件判断的结合
java·数据结构·算法
雪宫街道1 小时前
SpringBoot 向 IOC 容器注册组件的两种姿势:@Configuration 与 @Import
java·spring boot·后端·spring
北城以北88881 小时前
虚拟机安装JDK,Tomcat,部署项目
java·开发语言·tomcat