>데이터 베이스 >MySQL 튜토리얼 >첫 번째 SQL SELECT 쿼리가 행을 반환하지 않는 경우에만 두 번째 SQL SELECT 쿼리를 효율적으로 실행하려면 어떻게 해야 합니까?

첫 번째 SQL SELECT 쿼리가 행을 반환하지 않는 경우에만 두 번째 SQL SELECT 쿼리를 효율적으로 실행하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-28 02:54:10740검색

How Can I Efficiently Execute a Second SQL SELECT Query Only if the First Returns No Rows?

첫 번째 결과를 기반으로 조건부 두 번째 SELECT 쿼리 실행

PHP 스크립트의 효율성을 높이려면 데이터베이스 작업을 활용할 수 있습니다. 한 가지 최적화 기술은 첫 번째 SELECT 쿼리가 행을 반환하지 않거나 특정 조건이 충족되는 경우에만 다른 SELECT 쿼리를 실행하는 것입니다.

예를 들어 다음 쿼리를 고려해보세요.

SELECT * FROM proxies WHERE (A='B')
SELECT * FROM proxies WHERE (A='C')

조건부로 첫 번째 쿼리가 빈 집합을 반환하는 경우에만 두 번째 쿼리를 실행합니다. 다음 접근 방식을 사용할 수 있습니다.

IF (SELECT count(*) FROM proxies WHERE A='B')>0
    THEN SELECT * FROM proxies WHERE A='B'
ELSEIF (SELECT count(*) FROM proxies WHERE A='C')>0
    THEN SELECT * FROM proxies WHERE A='C'
END IF

그러나 이 접근 방식에는 각 쿼리를 실행하는 작업이 포함됩니다. 두 번, 한 번은 계산에, 한 번은 데이터 검색에 사용됩니다. 보다 효율적인 솔루션은 EXISTS:

SELECT * 
FROM proxies 
WHERE A='B'
UNION ALL
SELECT * 
FROM proxies 
WHERE A='C' AND NOT EXISTS (
    SELECT 1
    FROM proxies 
    WHERE A='B'
)

와 함께 UNION ALL을 활용하는 것입니다. 이 쿼리는 A='B'인 프록시 테이블에서 행이 존재하는 경우 검색합니다. 존재하지 않는 경우 A='C'인 행을 가져옵니다. 이 접근 방식은 데이터베이스 호출 수를 크게 줄여 스크립트 성능을 향상시킵니다.

위 내용은 첫 번째 SQL SELECT 쿼리가 행을 반환하지 않는 경우에만 두 번째 SQL SELECT 쿼리를 효율적으로 실행하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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