У меня вопрос с запросом HQL и спящим.
У меня есть класс пользователя и класс ролей. Пользователь может иметь много ролей. Поэтому у меня есть отношение ManyToMany:
В классе пользователя:
@ManyToMany(fetch = FetchType.LAZY)
@oinTable(name = "PORTAIL_USERROLE", joinColumns = { @JoinColumn(name = "USERID", nullable = false, updatable = false) }, inverseJoinColumns = { @JoinColumn(name = "ROLE", nullable = false, updatable = false) })
public Set<Portailrole> getPortailroles() {
return this.portailroles;
}
В классе ролей:
@ManyToMany(fetch = FetchType.LAZY)
@JoinTable(name = "PORTAIL_USERROLE", joinColumns = { @JoinColumn(name = "ROLE", nullable = false, updatable = false) }, inverseJoinColumns = { @JoinColumn(name = "USERID", nullable = false, updatable = false) })
public Set<Portailuser> getPortailusers() {
return this.portailusers;
}
Это сопоставление создало 3-ю таблицу (PORTAIL_USERROLE), где хранятся отношения. Все работают так. Когда у меня есть пользователь, я извлекаю роли.
Но, мой вопрос: в HQL-запросе, как я могу получить всех пользователей, которые имеют определенную роль? Любой класс представляет таблицу PORTAIL_USERROLE, поэтому я не знаю, как сделать свой запрос HQL.