Mybatisplus3.5.6,用String处理数据库列为JSONB字段

SQL建表语句:

复制代码
CREATE TABLE ts_data (
    device_sn varchar(300) NOT NULL,
    ts TIMESTAMPTZ NOT NULL,
    da JSONB NOT NULL,
    CONSTRAINT ts_data_pkey PRIMARY KEY (device_sn, ts, da)
);

数据库表Entity,这里字段da定义为String:

java 复制代码
@Data
@TableName("ts_data")
public class TsData {

    private String deviceSn;

    @TableField(value = "da", typeHandler = JsonbTypeHandler.class)
    private String da;

    @TableField("ts")  // 映射数据库中的TIMESTAMPTZ列
    private OffsetDateTime ts;

}

mybatis的自定义json处理器:

java 复制代码
import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedTypes;
import org.postgresql.util.PGobject;

import java.lang.reflect.Field;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

@Slf4j
@MappedTypes({Object.class})
public class JsonbTypeHandler extends JacksonTypeHandler {

    public JsonbTypeHandler(Class<?> type) {
        super(type);
    }

    // 自3.5.6版本开始支持泛型.
    public JsonbTypeHandler(Class<?> type, Field field) {
        super(type, field);
    }

    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, Object parameter, JdbcType jdbcType) throws SQLException {
        if (ps != null) {
            PGobject jsonObject = new PGobject();
            jsonObject.setType("jsonb");
            jsonObject.setValue(toJson(parameter));
            ps.setObject(i, jsonObject);
        }
    }


    @Override
    public Object getNullableResult(ResultSet rs, String columnName) throws SQLException {
        String json = rs.getString(columnName);
        if (json == null || json.trim().isEmpty()) {
            return null;
        }

        try {
            // 调用父类的反序列化方法
            return super.getNullableResult(rs, columnName);
        } catch (Exception e) {
            log.warn("反序列化JSON字段 {} 失败,原始内容: {}", columnName, json, e);
            // 可选:返回原始字符串而非抛出异常
            return json;
        }
    }


}

mybatis的xml文件中配置部分,需要指定自定义处理器:

XML 复制代码
<resultMap id="ResultTsMap" type="com.demo.entity.TsData">
        <result column="sn" property="sn" />
        <result column="ts" property="ts"  />
        <result column="da" property="da" javaType="java.lang.String" typeHandler="com.demo.config.handler.JsonbTypeHandler" />
</resultMap>

Mapper类中的新增方法,需要指定为jsonb:

java 复制代码
@Mapper
public interface TsDataMapper extends BaseMapper<TsData> {
    
	@Insert("insert into ts_data(device_sn,da,ts)values(#{sn},#{da}::jsonb,#{ts})")
    int insert(String sn, String da, OffsetDateTime ts);
	
}

如上所示,在新增数据时,就可以将String格式的json字段插入到表中列格式为jsonb的字段。

查询时,将从数据库中查询到的字符串显示转换成json即可。

相关推荐
想不明白的过度思考者6 分钟前
Spring Boot 配置文件深度解析
java·spring boot·后端
_OP_CHEN7 分钟前
【C++数据结构进阶】从B + 树 / B * 树到数据库索引:B树的进化之路与 MySQL 实战解析
数据结构·数据库·b树·mysql·innodb·b+树·mylsam
第二只羽毛9 分钟前
Java图书管理系统的设计与实现
java·大数据·安全·系统安全
cike_y5 小时前
Mybatis之解析配置优化
java·开发语言·tomcat·mybatis·安全开发
云老大TG:@yunlaoda3606 小时前
华为云国际站代理商TaurusDB的成本优化体现在哪些方面?
大数据·网络·数据库·华为云
TG:@yunlaoda360 云老大6 小时前
华为云国际站代理商GeminiDB的企业级高可用具体是如何实现的?
服务器·网络·数据库·华为云
是一个Bug7 小时前
Java基础50道经典面试题(四)
java·windows·python
Slow菜鸟7 小时前
Java基础架构设计(三)| 通用响应与异常处理(分布式应用通用方案)
java·开发语言
我是Superman丶7 小时前
《Spring WebFlux 实战:基于 SSE 实现多类型事件流(支持聊天消息、元数据与控制指令混合传输)》
java
廋到被风吹走7 小时前
【Spring】常用注解分类整理
java·后端·spring