집 >데이터 베이스 >MySQL 튜토리얼 >오늘을 포함하여 지난 30일 동안의 MySQL 레코드를 선택하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!