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

MySQL에서 날짜를 date_format과 비교할 때 정확한 결과를 보장하는 방법은 무엇입니까?

2024년 11월 12일에 게시됨
검색:171

When Comparing Dates with date_format in MySQL, How to Ensure Accurate Results?

date_format을 사용한 MySQL 날짜 비교

MySQL은 시간순 제약 조건에 따라 레코드를 필터링할 수 있는 날짜 비교 기능을 제공합니다. date_format과 같은 함수를 사용하여 사용자 친화적인 형식으로 날짜를 표시하는 것이 필요한 경우가 많지만 날짜 범위를 쿼리할 때 복잡해질 수 있습니다.

일반적인 시나리오에서는 date_format을 사용하여 형식이 지정된 날짜를 비교하여 다음과 같이 변환합니다. 문자열. 문자열을 비교하면 알파벳 순서로 인해 의도치 않게 유효한 날짜가 제외될 수 있습니다. 예를 들어, 문자열 '28-10-2012'와 '02-11-2012'를 오름차순으로 비교할 때 '28-10-2012'는 '02-11-2012' 뒤에 잘못 배치됩니다. 일 구성 요소의 숫자가 다른 날짜 문자열의 '0'보다 큽니다.

이 문제를 해결하고 정확한 날짜 비교를 보장하려면 다음이 중요합니다. 날짜를 날짜로 비교합니다. 이는 DATETIME 또는 DATE 필드에서 날짜 구성요소를 추출한 다음 결과 날짜 값을 비교하는 날짜 함수를 사용하여 달성할 수 있습니다.

아래 수정된 쿼리는 날짜 함수를 사용하여 날짜를 비교하는 방법을 보여줍니다.

select date_format(date(starttime),'%d-%m-%Y') from data
where date(starttime) >= date '2012-11-02';

이 쿼리에서 date(starttime) 함수는 starttime 필드에서 날짜 구성 요소를 추출하고 결과 날짜 값은 다음을 사용하여 비교됩니다. >= 연산자. 이렇게 하면 '2012-11-02' 이후의 날짜만 검색됩니다.

날짜를 날짜로 비교하면 문자열 비교와 관련된 알파벳 순서 제약 조건을 극복하고 쿼리 결과에 반영되도록 할 수 있습니다. 의도한 연대순 기준.

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

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

Copyright© 2022 湘ICP备2022001581号-3