在 Grails 中使用 Groovy Enum 作为 Id 字段

发布于 2025-01-08 16:31:11 字数 730 浏览 0 评论 0原文

我们在 GORM 中有一些遗留数据库映射,其中一些有一个主键,它是一个枚举。枚举使用字符串值而不是序数存储。

例如:

class AccountingGLMap {
    AccountingTypeCode id
    String typeCode

    static mapping = {
        id(column: 'accountingTypeCode',  generator: 'assigned')
    }
}

当您尝试检索实例时,您会得到:

| Error 2012-02-23 10:32:41,319 [pool-5-thread-1] ERROR context.GrailsContextLoader  - Error executing bootstraps: could not deserialize; nested exception is org.hibernate.type.SerializationException: could not deserialize

我已验证表中的值是否正确映射到给定的枚举中(只要它不是主键,我就可以使用枚举实例化对象)。如果我们将枚举更改为字符串,则一切正常。

我确实看到一篇文章声称在使用 JPA 时不能使用 Enum 作为主键,但即使这一点也存在争议。

有人有这样做的经验吗?

编辑:作为参考,我们针对 Oracle 数据库使用 2.0.1。

We have some legacy database mappings in GORM and several have a primary key which is an enumeration. The enumeration are stored using the string values, not the ordinals.

For example:

class AccountingGLMap {
    AccountingTypeCode id
    String typeCode

    static mapping = {
        id(column: 'accountingTypeCode',  generator: 'assigned')
    }
}

When you try to retrieve an instance, you get:

| Error 2012-02-23 10:32:41,319 [pool-5-thread-1] ERROR context.GrailsContextLoader  - Error executing bootstraps: could not deserialize; nested exception is org.hibernate.type.SerializationException: could not deserialize

I have verified that the values in the table map properly into the enumeration given (I can instantiate the object with the Enum so long as it's not the primary key). If we change the Enum to a String, everything works fine.

I did see an article claiming you can't use an Enum as the primary key when using JPA, but even that was disputed.

Anyone have experience doing this?

EDIT: For reference we are using 2.0.1 against an Oracle database.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

不语却知心 2025-01-15 16:31:11

type: 'string' 添加到您的 id 映射中,然后为 id 添加一个接受 String 输入的 setter,如下所示:

class AccountingGLMap {
    AccountingTypeCode id
    GLTypeCode glTypeCode

    static mapping = {
        id(column: 'accountingTypeCode', type: 'string', generator: 'assigned')
    }

    void setId(String value) {
        id = value
    }
}

Add type: 'string' to your id mapping and then add a setter for id that takes a String input like so:

class AccountingGLMap {
    AccountingTypeCode id
    GLTypeCode glTypeCode

    static mapping = {
        id(column: 'accountingTypeCode', type: 'string', generator: 'assigned')
    }

    void setId(String value) {
        id = value
    }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文