栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在JPA中使用Postgres JSONB数据类型?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在JPA中使用Postgres JSONB数据类型?

所有的答案都帮助我达成了最终的解决方案,该解决方案可以用于JPA,而不是专门用于Eclipselink或Hibernate。

import com.fasterxml.jackson.core.type.TypeReference;import com.fasterxml.jackson.databind.ObjectMapper;import java.io.IOException;import javax.json.Json;import javax.json.JsonObject;import javax.persistence.Converter;import org.postgresql.util.PGobject;@Converter(autoApply = true)public class JsonConverter implements javax.persistence.AttributeConverter<JsonObject, Object> {  private static final long serialVersionUID = 1L;  private static ObjectMapper mapper = new ObjectMapper();  @Override  public Object convertToDatabaseColumn(JsonObject objectValue) {    try {      PGobject out = new PGobject();      out.setType("json");      out.setValue(objectValue.toString());      return out;    } catch (Exception e) {      throw new IllegalArgumentException("Unable to serialize to json field ", e);    }  }  @Override  public JsonObject convertToEntityAttribute(Object dataValue) {    try {      if (dataValue instanceof PGobject && ((PGobject) dataValue).getType().equals("json")) {        return mapper.reader(new TypeReference<JsonObject>() {        }).readValue(((PGobject) dataValue).getValue());      }      return Json.createObjectBuilder().build();    } catch (IOException e) {      throw new IllegalArgumentException("Unable to deserialize to json field ", e);    }  }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/410097.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号