>데이터 베이스 >MySQL 튜토리얼 >MySQL 날짜 범위에서 누락된 날짜를 채우는 방법은 무엇입니까?

MySQL 날짜 범위에서 누락된 날짜를 채우는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-23 16:56:09775검색

How to Fill Missing Dates in MySQL Date Ranges?

MySQL의 날짜 범위에서 누락된 날짜 채우기

MySQL에서 누락된 날짜를 처리하려면 필요한 날짜를 결정하고 적절한 값으로 공백을 채워야 합니다. 다행히도 NUMBERS 테이블 트릭을 활용하여 오름차순 날짜 목록을 생성하는 해결책이 있습니다.

먼저 자동 증가 ID 열이 포함된 NUMBERS 테이블을 만듭니다.

<code class="language-sql">CREATE TABLE numbers (
  id int(10) unsigned NOT NULL auto_increment,
   PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;</code>

INSERT 문을 사용하여 필요한 수의 값으로 테이블을 채웁니다.

다음으로 DATE_ADD를 사용하여 id 값을 기반으로 날짜 목록을 생성합니다.

<code class="language-sql">SELECT DATE_ADD('2010-06-06', INTERVAL `n`.`id` - 1 DAY)
FROM `numbers` `n`
WHERE DATE_ADD('2010-06-06', INTERVAL `n`.`id` -1 DAY) <= '2010-06-14'</code>

'2010-06-06' 및 '2010-06-14'를 각각 원하는 시작일과 종료일로 바꾸세요.

마지막으로 시간 부분과 데이터 테이블을 기반으로 LEFT JOIN을 수행합니다.

<code class="language-sql">SELECT `x`.`ts` AS `timestamp`,
          COALESCE(`y`.`score`, 0) AS `cnt`
     FROM (SELECT DATE_FORMAT(DATE_ADD('2010-06-06', INTERVAL `n`.`id` - 1 DAY), '%Y-%m-%d') AS `ts`
             FROM `numbers` `n`
            WHERE DATE_ADD('2010-06-06', INTERVAL `n`.`id` - 1 DAY) <= '2010-06-14') x
LEFT JOIN `y` ON STR_TO_DATE(`y`.`date`, '%d.%m.%Y') = STR_TO_DATE(`x`.`ts`, '%Y-%m-%d')</code>

이 쿼리에서는 누락된 날짜가 0으로 채워집니다. 원래 날짜 형식을 유지하려면 DATE_FORMAT(x.ts, '%d.%m.%Y') AS timestamp을 사용하세요. 날짜 형식이 일관되고 y 함수가 변환에 사용되도록 여기에서 STR_TO_DATE 테이블이 수정되었습니다. 이는 원본 기사의 방법보다 더 안정적입니다.

위 내용은 MySQL 날짜 범위에서 누락된 날짜를 채우는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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