>데이터 베이스 >MySQL 튜토리얼 >EXISTS 절 최적화: SELECT 1 대 SELECT * — 그게 중요합니까?

EXISTS 절 최적화: SELECT 1 대 SELECT * — 그게 중요합니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-15 20:48:43683검색

EXISTS Clause Optimization: SELECT 1 vs. SELECT * — Does it Matter?

*EXISTS 절 성능: SELECT 1 대 SELECT **

SQL에서는 EXISTS 절을 사용하여 서브 쿼리에 지정된 조건과 일치하는 행이 있는지 확인합니다. 개발자들은 오랫동안 EXISTS 쿼리에서 SELECT 1과 SELECT *를 모두 사용해 왔습니다. 이는 어떤 접근 방식이 더 효율적인가라는 질문을 불러일으킵니다.

SQL 서버 최적화

Microsoft에 따르면 SQL Server는 하위 쿼리의 SELECT 목록에 관계없이 EXISTS 사용을 인식할 만큼 똑똑하다고 합니다. 시스템에 데이터를 반환하지 않으므로 SELECT * 및 SELECT 1 절은 성능 측면에서 동일합니다.

Microsoft 문서에 따르면:

"EXISTS에 의해 도입된 하위 쿼리의 선택 목록에는 거의 항상 별표()가 포함되어 있습니다. 조건을 만족하는 행이 있는지 테스트하는 것이므로 열 이름을 나열할 이유가 없습니다. 하위 쿼리에 지정됨 .*"

자체검증

이 동작을 확인하려면 다음 쿼리를 실행할 수 있습니다.

<code class="language-sql">SELECT whatever
FROM yourtable
WHERE EXISTS(SELECT 1/0
                 FROM someothertable
                WHERE a_valid_clause)</code>

SELECT 목록이 참여하는 경우 이 쿼리는 0으로 나누기 오류를 발생시킵니다. 그러나 SQL Server는 EXISTS 절의 컨텍스트를 이해하므로 SELECT 목록에서 어떤 계산도 수행하지 않습니다.

SQL 표준

ANSI SQL 1992 표준은 EXISTS 조건자의 컨텍스트에서 선택 목록 "*"가 모든 리터럴 값과 동일하다는 점을 명시하여 이 동작을 더욱 명확하게 설명합니다.

결론

SQL Server에서는 EXISTS 절에서 SELECT 1 및 SELECT *를 선택해도 성능에 영향을 미치지 않습니다. 최적화 프로그램이 해당 목적을 인식하고 시스템에 데이터를 반환하지 않기 때문에 두 방법 모두 동일한 결과를 생성합니다.

위 내용은 EXISTS 절 최적화: SELECT 1 대 SELECT * — 그게 중요합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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