집 >데이터 베이스 >MySQL 튜토리얼 >MySQL의 UNION 연산자를 사용할 때 테이블당 결과를 제한하는 방법은 무엇입니까?
MySQL에서 UNION 및 LIMIT 연산자 결합
UNION 연산자를 사용하여 여러 테이블의 데이터를 쿼리하는 경우 각 결과 집합에 별도로 LIMIT 연산자를 적용해야 할 수도 있습니다. 이는 각 SELECT 문을 둘러싼 괄호 안에 LIMIT를 배치하여 수행됩니다.
다음 예는 특정 두 회사에서 20개의 일자리를 추출하도록 설계되었으며 회사당 일자리는 10개로 제한됩니다.
잘못된 예:
<code class="language-sql">SELECT c.name, j.title, j.`desc`, j.link FROM jobs_job j INNER JOIN companies_company c ON j.company_id = c.id WHERE c.name IN ('Company1') UNION SELECT c.name, j.title, j.`desc`, j.link FROM jobs_job j INNER JOIN companies_company c ON j.company_id = c.id WHERE c.name IN ('Company2') ORDER BY name, title LIMIT 20;</code>
위 코드 중 LIMIT 20은 단일 SELECT 문이 아닌 UNION 이후의 결과 집합에 대해 작동합니다.
올바른 예:
<code class="language-sql">(SELECT c.name, j.title, j.`desc`, j.link FROM jobs_job j INNER JOIN companies_company c ON j.company_id = c.id WHERE c.name = 'Company1' ORDER BY name, title LIMIT 10) UNION (SELECT c.name, j.title, j.`desc`, j.link FROM jobs_job j INNER JOIN companies_company c ON j.company_id = c.id WHERE c.name = 'Company2' ORDER BY name, title LIMIT 10);</code>
각 SELECT 문을 괄호로 묶고 LIMIT 10을 개별적으로 적용함으로써 결과를 각 회사의 상위 10개 위치로 효과적으로 제한합니다. 회사의 직위가 10개 미만인 경우에도 쿼리는 사용 가능한 모든 결과를 반환합니다.
이 접근 방식은 "단일 SELECT에 ORDER BY 또는 LIMIT를 적용하려면 해당 절을 SELECT 주위의 괄호 안에 배치하세요"라는 문서의 지침을 따릅니다. 이 방법은 각 하위 쿼리만 정렬하고 제한하며 최종 결과를 정렬하려면 추가 처리가 필요하다는 점에 유의해야 합니다. 병합된 최종 결과를 정렬해야 하는 경우 가장 바깥쪽 수준에 또 다른 ORDER BY 문을 추가해야 합니다.
위 내용은 MySQL의 UNION 연산자를 사용할 때 테이블당 결과를 제한하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!