"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > MySQL에서 DATE_FORMAT()을 사용하여 정확한 날짜 비교를 달성하는 방법은 무엇입니까?

MySQL에서 DATE_FORMAT()을 사용하여 정확한 날짜 비교를 달성하는 방법은 무엇입니까?

2024-11-03에 게시됨
검색:482

How to Achieve Accurate Date Comparisons with DATE_FORMAT() in MySQL?

DATE_FORMAT()을 사용한 MySQL 날짜 비교

이 문서에서는 DATE_FORMAT()을 사용하여 MySQL에서 날짜 비교를 수행하는 방법을 살펴보겠습니다. 함수는 날짜를 비교하는 동안 사용자가 직면한 특정 문제를 해결합니다.

문제

사용자는 DATE_FORMAT()을 사용하여 날짜를 비교할 때 문제에 직면했습니다. 날짜는 쉽게 정렬할 수 없는 형식인 '%d-%m-%Y' 형식으로 저장되었습니다. 아래 쿼리를 사용하여 사용자는 날짜 비교를 시도했습니다.

SELECT DATE_FORMAT(DATE(starttime), '%d-%m-%Y')
FROM data
WHERE DATE_FORMAT(DATE(starttime), '%d-%m-%Y') >= '02-11-2012';

그러나 결과에는 '28-10-2012'가 포함되었습니다. 사용자의 기대에 따라 정확하지 않습니다.

해결책

날짜 대신 문자열을 비교하기 때문에 문제가 발생합니다. DATE_FORMAT()은 날짜를 문자열로 변환하고 문자열은 사전순으로 비교됩니다. 이 경우 '2012-10-28'은 '02-11-2012'가 나중 날짜임에도 불구하고 사전순으로 '02-11-2012'보다 큽니다.

날짜를 정확하게 비교하려면 다음이 필요합니다. 문자열이 아닌 날짜로 비교합니다. 다음 쿼리와 같이 DATE() 함수를 사용하여 시작 시간 필드에서 날짜 구성 요소를 추출한 다음 >= 연산자를 사용하여 날짜를 비교할 수 있습니다.

SELECT DATE_FORMAT(DATE(starttime), '%d-%m-%Y')
FROM data
WHERE DATE(starttime) >= DATE('2012-11-02');

이 쿼리는 날짜를 올바르게 비교하고 결과에서 '28-10-2012'를 제외합니다.

추가 고려 사항

DATETIME 필드 시작 시간을 DATE 필드로 변경할 수 있는지 고려해 볼 가치가 있습니다. 이렇게 하면 반복적인 변환이 필요하지 않아 잠재적으로 성능이 향상됩니다.

릴리스 선언문 이 글은 1729738847에서 재인쇄되었습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3