[英]Hibernate: ManyToMany unidirectional only returning one record
我有这个问题,不胜感激。
我有一个用户实体。 用户具有角色(多对一关系)。 角色具有权限列表(我遇到麻烦的许多关系)。
在我的代码中,我要通过用户名从数据库中选择一个用户。
当我检索用户时,该用户的角色就在其中。 但是在角色内部,应该有一个权限列表。 应该有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;
}
RoleEntity:
@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。
在用户表中,有一个role_id字段。 我选择的用户的此字段填充为1。
好的没关系。 我已经为此工作了一段时间,当我发布此消息后,我就知道了!
在@JoinTable批注中,我错误地使用了“ role_id”和“ permission_id”!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.