집 >데이터 베이스 >MySQL 튜토리얼 >일치하는 행이 없을 때 SQL에서 기본값을 반환하는 방법은 무엇입니까?
단일 행을 찾을 수 없을 때 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!