>데이터 베이스 >MySQL 튜토리얼 >일치하는 행이 없을 때 SQL에서 기본값을 반환하는 방법은 무엇입니까?

일치하는 행이 없을 때 SQL에서 기본값을 반환하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-29 18:54:301065검색

How to Return Default Values in SQL When No Matching Rows are Found?

단일 행을 찾을 수 없을 때 SQL로 기본값 반환

SQL 쿼리를 사용하여 데이터베이스에서 데이터를 검색할 때 다음을 수행하는 것이 바람직한 경우가 많습니다. 일치하는 행이 없으면 기본값을 반환합니다. 이는 쿼리 출력이 애플리케이션에서 표시하거나 처리하기 위한 상황을 처리할 때 특히 유용합니다.

원래 쿼리

다음 SQL 쿼리를 고려하세요. 스트림의 다음 예약 항목 검색:

<code class="sql">SELECT `file`
FROM `show`, `schedule`
WHERE `channel` = 1
  AND `start_time` <= UNIX_TIMESTAMP()
  AND `start_time` > UNIX_TIMESTAMP()-1800
  AND `show`.`id` = `schedule`.`file`
ORDER BY `start_time`
DESC LIMIT 1</code>

이 쿼리는 지정된 기준을 충족하는 가장 최근 예약 항목을 반환합니다. 그러나 일치하는 행이 없으면(즉, 지난 30분 이내에 예약된 항목이 없는 경우) 빈 결과가 반환됩니다.

기본값 접근 방식

이 시나리오를 처리하고 일치하는 행이 없을 때 기본값을 반환하려면 다음과 같은 여러 접근 방식을 사용할 수 있습니다.

집계를 사용한 COALESCE/IFNULL

한 가지 방법은 집계 함수와 함께 COALESCE 또는 IFNULL 함수를 사용합니다. 이 접근 방식을 사용하면 쿼리 결과가 비어 있어도 null이 아닌 값이 반환됩니다. 예:

<code class="sql">SELECT IFNULL(MIN(`file`), 'default.webm') `file`
  FROM `show`, `schedule`
 WHERE `channel` = 1
   AND `start_time` <= UNIX_TIMESTAMP()
   AND `start_time` > UNIX_TIMESTAMP()-1800
   AND `show`.`id` = `schedule`.`file`
 ORDER BY `start_time` DESC LIMIT 1</code>

이 쿼리에서는 MIN() 집계 함수를 사용하여 파일 열의 최소값을 반환합니다. 이렇게 하면 행을 선택하지 않은 경우 NULL 값이 반환됩니다. 그런 다음 IFNULL 또는 COALESCE 함수는 NULL 값을 기본값 'default.webm'으로 바꿉니다.

이 솔루션은 일치하는 행이 없을 때 효과적으로 기본값을 반환하므로 애플리케이션이 예약된 항목의 부재를 처리할 수 있습니다. 적절하게.

위 내용은 일치하는 행이 없을 때 SQL에서 기본값을 반환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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