Hibernate 复合键和重叠字段 - 如何避免列重复

2024-01-03

我面临着如何管理特定模型的映射的问题。

这是一个多租户应用程序,我们选择在每个实体中包含“tenant_id”,因此我们不必每次需要获取实体时都进行联合(事实上,这是我的问题的根源...)。

模型如下:

+--------------------+   +---------------+
|        Book        |   |    Author     |
+--------------------+   +---------------+
| id (pk)            |   | id (pk)       |
| tenant_id (pk)(fk) |   | tenant_id (pk |
| author_id (fk)     |   | name          |
| title              |   +---------------+
+--------------------+

如您所见,租户 ID 位于每个实体中,并且是主键的一部分。我们使用@IdClass来管理组合键。这是代码:


    @Data
    public class TenantAwareKey implements Serializable {

        private UUID id;
        private Integer tenantId;
    }


    @IdClass(TenantAwareKey.class)
    @Entity
    @Table(name = "BOOK")
    @Data
    public class Book {

        @Id
        @GeneratedValue
        @Column(name = "ID")
        private UUID id;
        @Id
        @Column(name = "TENANT_ID")
        private Integer tenantId;

        private String title;

        @ManyToOne
        @JoinColumns(
            value = {
                @JoinColumn(referencedColumnName = "id", name = "author_id"),
                @JoinColumn(referencedColumnName = "tenant_id", name = "tenant_id", insertable = false, updatable = false)
            })
        private Author author;   
    }


    @IdClass(TenantAwareKey.class)
    @Entity
    @Data
    public class Author {
        @Id
        @GeneratedValue
        @Column(name = TenantAwareConstant.ENTITY_ID_COLUMN_NAME)
        private UUID id;
        @Id
        @Column(name = TenantAwareConstant.TENANT_ID_COLUMN_NAME)
        private Integer tenantId;

        private String name;
    }

然后,当运行我的应用程序时,我最终得到:


    Caused by: org.hibernate.AnnotationException: Mixing insertable and non insertable columns in a property is not allowed: 
    com.pharmagest.durnal.tenant.entity.BookNoDuplicateColumn.author
        at org.hibernate.cfg.Ejb3Column.checkPropertyConsistency(Ejb3Column.java:725)
        at org.hibernate.cfg.AnnotationBinder.bindManyToOne(AnnotationBinder.java:3084)
    (...)

如果我不尝试“相互化”tenant_id 列,我设法使其工作,当我只有一个具有此tenant_id 的外键时,这是可以接受的,但随着外键数量的增加,它会越来越少,导致添加每次都有一个tenant_id列,重复信息并破坏内存......

经过一番挖掘,我在 Hibernate 中发现了一个未解决的问题:https://hibernate.atlassian.net/browse/HHH-6221 https://hibernate.atlassian.net/browse/HHH-6221

它已经很多年没有修复了......所以,我的问题是:您是否遇到过这样的映射,当我有一个与主键共享字段的外键时,是否有解决方案可以避免重复的列?


如上所述here https://stackoverflow.com/a/13147366/3869137,您可以通过对 id_tenant 列使用 @JoinColumnOrFormula 来绕过验证。

您应该像这样映射作者的关联:

    @JoinColumnsOrFormulas(
        value = {
                @JoinColumnOrFormula(column = @JoinColumn(referencedColumnName = "id", name = "author_id")),
                @JoinColumnOrFormula(formula = @JoinFormula(referencedColumnName = "tenant_id", value = "tenant_id"))
        })
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Hibernate 复合键和重叠字段 - 如何避免列重复 的相关文章

随机推荐