집 >데이터 베이스 >MySQL 튜토리얼 >SQL에서 여러 역할 ID가 있는 고유한 사용자 ID를 선택하는 방법은 무엇입니까?
여러 행에 걸쳐 특정 역할 ID 기준을 충족하는 사용자 ID 검색
이 문서에서는 데이터베이스 테이블 내의 여러 행에 분산된 여러 역할 ID 조건을 충족하는 고유한 사용자 ID를 선택하는 과제를 다룹니다. userrole
및 userid
열이 있는 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>
이 쿼리는 세 가지 자체 조인을 사용합니다. t1
는 roleid
1로 사용자를 선택합니다. t2
roleid
2개도 갖도록 보장합니다. t3
은 roleid
3이 있는지 확인합니다. DISTINCT
은 고유한 userid
값만 반환되도록 합니다.
최적의 접근 방식(집계 및 조인)은 테이블 크기와 데이터 분포에 따라 다릅니다. 행 일치 가능성이 낮은 시나리오의 경우 자체 조인 방법이 더 나은 성능을 발휘하는 경향이 있습니다.
위 내용은 SQL에서 여러 역할 ID가 있는 고유한 사용자 ID를 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!