gpt4 book ai didi

java - hibernate 注解。 @Where 与 @WhereJoinTable

转载 作者:塔克拉玛干 更新时间:2023-11-01 22:21:29 29 4
gpt4 key购买 nike

遵循 java 文档

@哪里

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

@WhereJoinTable

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

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

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

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

最佳答案

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

@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 集合中。

关于java - hibernate 注解。 @Where 与 @WhereJoinTable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45504002/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com