首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Hibernate注解。@Where vs @Where

Hibernate注解。@Where vs @Where
EN

Stack Overflow用户
提问于 2017-08-04 18:07:55
回答 1查看 8.6K关注 0票数 7

下面是java文档

@Where

Where子句添加到集合的元素实体或目标实体。这个子句是用SQL编写的。这里的一个常见用例是软删除。

@WhereJoinTable

要添加到集合联接表中的Where子句。这个子句是用SQL编写的。就像{@link Where}一样,一个常见的用例是实现软删除。

似乎注释通常也可以以相同的方式使用:

代码语言:javascript
复制
|---------------------|-------------------|-------------------|
|                     |@Where             | @WhereTable       |
|---------------------|-------------------|-------------------|
|target elements      |TYPE, METHOD, FIELD|TYPE, METHOD, FIELD|
|---------------------|-------------------|-------------------|
|Retention            |RUNTIME            |RUNTIME            |
|---------------------|-------------------|-------------------|
|properties           |clause             |clause             |
|---------------------|-------------------|-------------------|

结果,我真的很困惑,我应该如何知道我应该为关系字段使用哪个注释。我找不到使用@Where@WhereJoinTable的区别。两者都可以相互替代,我说的对吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-11-27 19:16:03

第一个注解应用于目标实体。下面是这种情况的伪代码的非常简单的例子:

代码语言:javascript
复制
@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集合中。

第二个注解被应用于关联表。下面是另一个伪代码示例,但现在我们假设关联表不像第一种情况那样微不足道:

代码语言:javascript
复制
@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集合中。

票数 13
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45504002

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档