> 데이터 베이스 > MySQL 튜토리얼 > 누락된 데이터에 대해 IN 쿼리를 사용하여 기본값이 있는 레코드를 검색하는 방법은 무엇입니까?

누락된 데이터에 대해 IN 쿼리를 사용하여 기본값이 있는 레코드를 검색하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2025-01-17 06:46:08
원래의
850명이 탐색했습니다.

How to Retrieve Records with Default Values Using IN Queries for Missing Data?

IN 쿼리를 사용하여 누락된 데이터에 대한 기본값이 있는 레코드 검색

IN 절을 사용하여 특정 날짜 범위 내의 사용자 온라인 활동을 쿼리할 때 IN 조건의 일부 사용자 ID에 OnlineUsage 테이블의 해당 항목이 없는 상황이 발생할 수 있습니다. 이를 처리하고 누락된 데이터에 대한 기본값을 반환하려면 수정된 쿼리 구조가 필요합니다.

표준 쿼리는 레코드가 일치하는 ID에 대한 결과만 반환할 수 있습니다. IN 목록의 모든 ID를 포함하려면 일치하는 온라인 사용 데이터가 없는 ID라도 LEFT JOIN(또는 이에 상응하는 항목)을 활용하도록 쿼리를 재구성하세요. 핵심은 날짜 범위 조건을 WHERE 절에서 JOIN 조건

으로 이동하는 것입니다.
<code class="language-sql">SELECT
    users.Name,
    users.ID,
    IFNULL(SUM(OnlineUsage.Minutes), 0) AS MinutesOnline
FROM
    users
    LEFT JOIN OnlineUsage ON users.ID = OnlineUsage.ID
        AND OnlineUsage.Date >= '2016-01-01 00:00:00' AND OnlineUsage.Date < '2017-01-01 00:00:00'
WHERE users.ID IN (1, 2, 3, 4, 5) -- Your list of IDs here
GROUP BY users.ID;</code>
로그인 후 복사

이 수정된 쿼리는 LEFT JOIN을 사용하여 모든 사용자가 포함되도록 합니다. IFNULL 함수는 SUM(OnlineUsage.Minutes)을 대체하여 NULL이 (온라인 사용 데이터가 없는 사용자의 경우) 0을 반환하는 경우를 처리합니다. GROUP BY 절은 각 사용자에 대해 MinutesOnline을 올바르게 집계하는 데 중요합니다. 이 접근 방식은 완전한 데이터 세트를 보장하여 온라인 사용 기록이 있는지 여부에 관계없이 지정된 기간 내의 모든 사용자에 대한 일관된 표현을 제공합니다.

위 내용은 누락된 데이터에 대해 IN 쿼리를 사용하여 기본값이 있는 레코드를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿