随笔 - 836  文章 - 1 评论 - 40 阅读 - 102万
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

 

自定转换器:

复制代码

package com.comon.utils;


import java.io.IOException;
import java.io.Serializable;

import javax.persistence.AttributeConverter;

import com.fasterxml.jackson.databind.ObjectMapper;

import lombok.extern.slf4j.Slf4j;


@Slf4j
public class JpaConverterJsonUtils implements AttributeConverter<Object,String>,Serializable {

    /**
     * 
     */
    private static final long serialVersionUID = 1L;
    private static final ObjectMapper OBJECT_MAPPER = new ObjectMapper();
    
    public String convertToDatabaseColumn(Object attribute) {
        try {
            return OBJECT_MAPPER.writeValueAsString(attribute);
        } catch (Exception e) {
            log.error("convert data error,the exception is {}",e);
            return null;
        }
        
    }

    public Object convertToEntityAttribute(String dbData) {
        try {
            if(dbData!=null){
                return OBJECT_MAPPER.readValue(dbData, Object.class);
            }
        } catch (IOException e) {
            log.error("convert data error,the exception is {}",e);
            return null;
        }
        return dbData;
    }

}
复制代码

 

 

使用: 在自定名字上添加  eg: XXXX.DO   

    @Convert(converter=JpaConverterJsonUtils.class)
    private List<JSONObject> milestones; //在db中为json 类型

 

posted on   lshan  阅读(4025)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示