Hibernate注释。@Where与@WhereJoinTable的区别。

7

以下是Java文档的翻译:

@Where

@Where注解用于向元素实体或集合目标实体添加where子句。该子句使用SQL语法编写,常见用途是实现软删除。

@WhereJoinTable

@WhereJoinTable注解用于向集合连接表添加where子句。该子句使用SQL语法编写,与@Where注解类似,常见用途是实现软删除。

总的来说,在一般情况下,这些注解的用法都相同。

|---------------------|-------------------|-------------------|
|                     |@Where             | @WhereTable       |
|---------------------|-------------------|-------------------|
|target elements      |TYPE, METHOD, FIELD|TYPE, METHOD, FIELD|
|---------------------|-------------------|-------------------|
|Retention            |RUNTIME            |RUNTIME            |
|---------------------|-------------------|-------------------|
|properties           |clause             |clause             |
|---------------------|-------------------|-------------------|

因此,我非常困惑应该使用哪个注释来处理关系字段。我无法找到使用@Where@WhereJoinTable之间的区别。它们两者都可以互相替换,对吗?

1个回答

13

第一个注释应用于目标实体。以下是伪代码中此情况的非常简化示例:

首先对目标实体进行注释。以下是这种情况的伪代码示例:

@Entity
public class Role {
    private Long id;
    private boolean enabled;
}     

@Entity
public class User {
    @OneToMany(fetch = FetchType.LAZY)
    @JoinTable(name = "USER_ROLE", joinColumns = @JoinColumn(name = "USER_ID"), inverseJoinColumns = @JoinColumn(name = "ROLE_ID"))
    @Where(clause = "enabled = true")
    private Set<Role> roles = new LinkedHashSet<>(0);
}

由此只有启用的角色会从数据库填充到User.roles集合中。

第二个注释应用于关联表。下面是另一个伪代码示例,但现在我们假设关联表不像第一种情况那么简单:

@Entity
public class Role {
    private Long id;
    private boolean enabled;
}   

@Entity
public class User {
    @OneToMany(fetch = FetchType.LAZY)
    @JoinTable(name = "USER_ROLE", joinColumns = @JoinColumn(name = "USER_ID"), inverseJoinColumns = @JoinColumn(name = "ROLE_ID"))
    @Where(clause = "enabled = true")
    @WhereJoinTable(clause = "now() between valid_from and valid_until")
    private Set<Role> roles = new LinkedHashSet<>(0);
}

and association table has validity attributes, something like 

CREATE TABLE USER_ROLE {
    ID NUMBER NOT NULL,
    USER_ID NUMBER NOT NULL,
    ROLE_ID NUMBER NOT NULL,
    VALID_FROM DATETIME,
    VALID_UNTIL DATETIME
} 

只有已启用且有效的角色才会从数据库中填充到“User.roles”集合中。


不错的示例,如果能够通过Git分享示例并检查结果的话,我更愿意这样做。无论如何,感谢您的时间和帮助。 - Sergii
您能否解释一下为什么这里需要使用 @WhereJoinTable 注解,而不能仅使用 @Where(clause = "enabled = true and now() between valid_from and valid_until") - end-user
不好意思,我不能帮忙了。我不再使用Hibernate,也记不起来详细信息了。 - Igor Bljahhin
1
@IgorBljahhin 这是因为“WhereJoinTable”应用于关联表(在上面的示例中,它适用于“USER_ROLE”)。而“Where”应用于目标实体表(在上面的示例中,它适用于“ROLE”)。如果按照您建议的方式编写,生成的SQL将导致where子句引用“ROLE.VALID_FROM”和“ROLE.VALID_UNTIL”,而不是“USER_ROLE.VALID_FROM”和“USER_ROLE.VALID_UNTIL”。这将导致SQL异常,因为USER没有名为“VALID_FROM”或“VALID_UNTIL”的列。USER_ROLE具有这些列。 - Nephthys76

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接