집 >데이터 베이스 >MySQL 튜토리얼 >첫 번째 SQL SELECT 쿼리가 행을 반환하지 않는 경우에만 두 번째 SQL SELECT 쿼리를 효율적으로 실행하려면 어떻게 해야 합니까?
첫 번째 결과를 기반으로 조건부 두 번째 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!