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