>데이터 베이스 >MySQL 튜토리얼 >MySQL의 UNION 연산자를 사용할 때 테이블당 결과를 제한하는 방법은 무엇입니까?

MySQL의 UNION 연산자를 사용할 때 테이블당 결과를 제한하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-14 12:57:44241검색

How to Limit Results Per Table When Using MySQL's UNION Operator?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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