带有Jooq newRecord和枚举的DataTypeException

时间:2016-06-01 05:20:34

标签: java sql enums jooq

我有一个名为Group的简单对象,其中包含GroupType枚举。

public enum GroupType {
    PRIMARY,
    SECONDARY
}

我构建了一个新的Group并将其保存

Group group = new Group();
group.setName(PRIMARY.name());
group.setType(PRIMARY);
Group g = save();

save

开始
R record = (R) dsl.newRecord(Groups.GROUPS, group);

这行代码正在抛出

  Caused by: org.jooq.exception.DataTypeException: Cannot convert from PRIMARY (class com.domain.entities.support.GroupType) to class com.domain.jooq.generated.enums.GroupType
    at org.jooq.tools.Convert$ConvertAll.fail(Convert.java:1113)
    at org.jooq.tools.Convert$ConvertAll.from(Convert.java:1002)
    at org.jooq.tools.Convert.convert0(Convert.java:316)
    at org.jooq.tools.Convert.convert(Convert.java:308)
    at org.jooq.tools.Convert.convert(Convert.java:380)
    at org.jooq.impl.DefaultDataType.convert(DefaultDataType.java:698)
    at org.jooq.impl.Tools.setValue(Tools.java:1975)
    at org.jooq.impl.AbstractRecord.from(AbstractRecord.java:829)

枚举如何与newRecord一起使用?

1 个答案:

答案 0 :(得分:0)

错误消息说明了:

Cannot convert from PRIMARY (class com.domain.entities.support.GroupType)
                          to class com.domain.jooq.generated.enums.GroupType

您的GroupType枚举似乎使用了两种不同的类型。 jOOQ只能理解jOOQ生成的枚举类型(com.domain.jooq.generated.enums.GroupType),而不是你自己的(com.domain.entities.support.GroupType)。

如果您真的想使用自己的枚举类型,则需要在Converter列上注册TYPE以在两种类型之间进行转换。