微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JPA AttributeConverter 不能与 json 列字段中的枚举一起使用

如何解决JPA AttributeConverter 不能与 json 列字段中的枚举一起使用

我有一张这样的桌子

CREATE TABLE `test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,`json_col` json NOT NULL,PRIMARY KEY (`id`)
)

我的数据模型如下

@Entity
@TypeDef(name = "json",typeClass = JsonStringType.class)
public class ServiceVersion extends EntityAuditing {

  @Id
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private int id;

  @NotNull
  @Type(type = "json")
  @Column(columnDeFinition = "json")
  private JsonColumn jsonCol;
}
@AllArgsConstructor
@Getter
public enum TestEnum {
  ABC("abc.com"),DEF("def.com");

  private String value;
}
public class JsonColumn {
  private TestEnum enumVal;
}

要转换枚举 TestEnum,我使用下面的 AttributeConverter

@Converter(autoApply = true)
public class EnumConverter implements AttributeConverter<TestEnum,String> {

  @Override
  public String convertToDatabaseColumn(TestEnum value) {
    if (value == null) {
      return null;
    }
    return value.getValue();
  }

  @Override
  public TestEnum convertToEntityAttribute(String value) {
    if (value == null) {
      return null;
    }

    return Stream.of(TestEnum.values())
        .filter(v -> v.getValue().equals(value))
        .findFirst()
        .orElseThrow(IllegalArgumentException::new);
  }
}

但如果枚举未定义为实体类中的列,则似乎不会调用 AttributeConverter 类。就我而言,我使用 hibernate-types 来存储 json。如何存储枚举及其值而不是名称

通过上面的代码,列json_col存储在DB中,枚举名称是这样的

{
  "enumVal": "ABC"
}

但是,我想像这样存储枚举值

{
  "enumVal": "abc.com"
}

解决方法

正如 documentation 中所述:

如果 autoApply 元素被指定为 true持久化提供者必须自动将转换器应用于持久化中所有实体的指定目标类型的所有映射属性除通过 Convert 批注(或 XML 等价物)覆盖其转换的属性之外的单元。

您的属性的目标类型是 JsonColumn,因此未应用转换器。转换器将自动应用于以下字段,例如:

@Column
private TestEnum testColumn;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。