下面是java文档
@Where
Where子句添加到集合的元素实体或目标实体。这个子句是用SQL编写的。这里的一个常见用例是软删除。
@WhereJoinTable
要添加到集合联接表中的Where子句。这个子句是用SQL编写的。就像{@link Where}一样,一个常见的用例是实现软删除。
似乎注释通常也可以以相同的方式使用:
|---------------------|-------------------|-------------------|
| |@Where | @WhereTable |
|---------------------|-------------------|-------------------|
|target elements |TYPE, METHOD, FIELD|TYPE, METHOD, FIELD|
|---------------------|-------------------|-------------------|
|Retention |RUNTIME |RUNTIME |
|---------------------|-------------------|-------------------|
|properties |clause |clause |
|---------------------|-------------------|-------------------|结果,我真的很困惑,我应该如何知道我应该为关系字段使用哪个注释。我找不到使用@Where和@WhereJoinTable的区别。两者都可以相互替代,我说的对吗?
发布于 2017-11-27 19:16:03
第一个注解应用于目标实体。下面是这种情况的伪代码的非常简单的例子:
@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集合中。
https://stackoverflow.com/questions/45504002
复制相似问题