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

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

Patricia Arquette
Patricia Arquette원래의
2024-12-20 13:18:09998검색

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으로 문의하세요.