gpt4 book ai didi

java - Hibernate:ManyToMany单向仅返回一条记录

转载 作者:行者123 更新时间:2023-12-02 00:57:14 25 4
gpt4 key购买 nike

我遇到了这个问题,希望得到任何帮助...

我有一个用户实体。用户有一个角色(多对一关系)。一个角色有一个权限列表(我遇到麻烦的多对多关系)。

在我的代码中,我通过用户名从数据库中选择一个用户。

当我检索用户时,用户的角色就在其中。但角色内部应该有一个权限列表。应该有 4 个权限,但每次我只能将一个元素放回到集合中。

我已经正确查询了数据库,该角色确实有4个权限,所以问题不存在。

用户实体:

@Table(name = "users")
public class UserEntity {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@NotEmpty
private String username;

@ManyToOne(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
@JoinColumn(name = "role_id")
private RoleEntity role;
}

角色实体:

@Table(name = "roles")
public class RoleEntity {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@NotEmpty
private String name;

private String description;

@ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
@JoinTable(name = "roles_permissions", joinColumns = @JoinColumn(name = "permission_id"),
inverseJoinColumns = @JoinColumn(name = "role_id"))
private Set<PermissionEntity> permissions = new HashSet<>();

}

这是我的存储库。我从服务中调用此方法,并且只是返回我上面描述的内容。

@Repository
public interface UserRepository extends CrudRepository<UserEntity, String> {

Optional<UserEntity> findByUsername(String username);
}

在我的数据库中,有一个名为“roles_permissions”的表,其中包含字段 role_id 和permission_id。这里有四条记录。对于所有角色,role_id 均为“1”,并且其链接到权限 1、2、3、4。

在users表中,有一个role_id字段。我选择的用户在此字段中填充了 1。

最佳答案

好吧,没关系。我已经研究这个问题有一段时间了,当我发布这篇文章时我就明白了!

在@JoinTable注释中,我的“role_id”和“permission_id”是错误的!

关于java - Hibernate:ManyToMany单向仅返回一条记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57805608/

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