簡體   English   中英

休眠:ManyToMany單向僅返回一個記錄

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM