> 데이터 베이스 > MySQL 튜토리얼 > 오늘을 포함하여 지난 30일 동안의 MySQL 레코드를 선택하는 방법은 무엇입니까?

오늘을 포함하여 지난 30일 동안의 MySQL 레코드를 선택하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-12-20 13:18:09
원래의
1022명이 탐색했습니다.

How to Select MySQL Records from the Last 30 Days, Including Today?

MySQL에서 오늘과 지난 30일 사이의 레코드 선택

MySQL에서는 다음을 사용하여 지정된 날짜 범위에 속하는 레코드를 검색할 수 있습니다. 다음과 같은 쿼리:

SELECT *
FROM table_name
WHERE date_column BETWEEN start_date AND end_date
로그인 후 복사

그러나 결과를 이전 30개로 제한하려고 하면 며칠 동안 사용자는 쿼리가 대신 모든 레코드를 반환하는 문제에 직면할 수 있습니다. 이 문제를 해결하려면 올바른 날짜 형식 구문을 이해하는 것이 중요합니다.

제공된 쿼리에서:

create_date between DATE_FORMAT(curdate(),'%m/%d/%Y') AND (DATE_FORMAT(curdate() - interval 30 day,'%m/%d/%Y'))
로그인 후 복사

DATE_FORMAT 함수가 WHERE 절 내에서 잘못 사용되었습니다. 표시 목적으로 검색된 날짜의 형식을 지정하려면 이 함수를 SELECT 절에 적용해야 합니다.

SELECT DATE_FORMAT(create_date, '%m/%d/%Y') AS formatted_date
FROM table_name
WHERE create_date BETWEEN CURDATE() - INTERVAL 30 DAY AND CURDATE()
로그인 후 복사

또한 create_date 열의 데이터 유형을 고려하는 것이 중요합니다. 0이 아닌 시간 구성 요소를 포함하는 DATETIME으로 저장되면 위 쿼리는 오늘의 레코드를 정확하게 선택하지 않습니다. 이러한 경우 대신 NOW()를 사용하십시오.

SELECT DATE_FORMAT(create_date, '%m/%d/%Y') AS formatted_date
FROM table_name
WHERE create_date BETWEEN NOW() - INTERVAL 30 DAY AND NOW()
로그인 후 복사

이러한 수정 사항을 적용하면 쿼리는 지정된 30일 범위 내에서 생성된 레코드를 원하는 'mm/dd/yy' 형식으로 올바르게 검색합니다. 형식입니다.

위 내용은 오늘을 포함하여 지난 30일 동안의 MySQL 레코드를 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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