>데이터 베이스 >MySQL 튜토리얼 >SQL에서 여러 역할 ID가 있는 고유한 사용자 ID를 선택하는 방법은 무엇입니까?

SQL에서 여러 역할 ID가 있는 고유한 사용자 ID를 선택하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-19 16:57:09726검색

How to Select Distinct User IDs with Multiple Role IDs in SQL?

여러 행에 걸쳐 특정 역할 ID 기준을 충족하는 사용자 ID 검색

이 문서에서는 데이터베이스 테이블 내의 여러 행에 분산된 여러 역할 ID 조건을 충족하는 고유한 사용자 ID를 선택하는 과제를 다룹니다. userroleuserid 열이 있는 roleid 테이블을 생각해 보겠습니다.

userid roleid
1 1
1 2
1 3
2 1

목표는 userid 값 1, 2, 3과 연관된 모든 개별 roleid 값을 식별하는 것입니다. 예제 데이터를 사용하면 예상되는 출력은 userid 1입니다. 두 가지 SQL 접근 방식으로 이를 달성할 수 있습니다.

방법 1: HAVING 절을 사용한 집계 쿼리

이 방법은 집계 함수와 HAVING 절을 활용합니다.

<code class="language-sql">SELECT userid
FROM userrole
WHERE roleid IN (1, 2, 3)
GROUP BY userid
HAVING COUNT(DISTINCT roleid) = 3;</code>

이 쿼리는 먼저 roleid이 1, 2 또는 3인 행을 필터링합니다. 그런 다음 결과를 userid별로 그룹화하고 다음을 사용하여 각 사용자에 대한 고유한 roleid 값의 수를 계산합니다. COUNT(DISTINCT roleid). HAVING 절은 정확히 3개의 서로 다른 역할 ID를 가진 사용자만 포함하도록 필터링합니다.

방법 2: Self Join 쿼리

특히 대규모 데이터 세트의 경우 더 효율적인 대안은 자체 조인 접근 방식입니다.

<code class="language-sql">SELECT DISTINCT t1.userid
FROM userrole t1
JOIN userrole t2 ON t1.userid = t2.userid AND t2.roleid = 2
JOIN userrole t3 ON t1.userid = t3.userid AND t3.roleid = 3
WHERE t1.roleid = 1;</code>

이 쿼리는 세 가지 자체 조인을 사용합니다. t1roleid 1로 사용자를 선택합니다. t2 roleid 2개도 갖도록 보장합니다. t3roleid 3이 있는지 확인합니다. DISTINCT은 고유한 userid 값만 반환되도록 합니다.

최적의 접근 방식(집계 및 조인)은 테이블 크기와 데이터 분포에 따라 다릅니다. 행 일치 가능성이 낮은 시나리오의 경우 자체 조인 방법이 더 나은 성능을 발휘하는 경향이 있습니다.

위 내용은 SQL에서 여러 역할 ID가 있는 고유한 사용자 ID를 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.