休眠状态:ManyToMany单向仅返回一条记录

时间:2019-09-05 12:33:35

标签: java hibernate spring-data-jpa many-to-many

我遇到了这个问题,感谢您的帮助...

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

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

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

我已经正确查询了数据库,并且确实有4个权限附加到该角色,所以问题不在那里。

UserEntity:

@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。

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

1 个答案:

答案 0 :(得分:0)

好的,没关系。我已经为此工作了一段时间,当我发布此消息后,我就知道了!

在@JoinTable批注中,我错误地使用了“ role_id”和“ permission_id”!