Подтвердить что ты не робот

HQL: запрос Hibernate с ManyToMany

У меня вопрос с запросом 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.

4b9b3361

Ответ 1

Это должно сделать это:

from Portailuser u join u.portailroles r where r.name=:roleName

Ответ 2

вы можете использовать   @WhereJoinTable  Вот так:

 @JoinTable(name = "OFFICE_USER_POSITION", joinColumns = {
        @JoinColumn(name = "user_id", referencedColumnName = "id")}, inverseJoinColumns = {
        @JoinColumn(name = "POST_ID", referencedColumnName = "id")})
@WhereJoinTable(clause = "primary_flag='" + YES + "' and del_flag='" + DEL_FLAG_NORMAL + "'")