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;

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...