SQL Server에서 DATETIME과 DATE 값을 올바르게 비교하려면 어떻게 해야 합니까?
Jan 04, 2025 pm 05:27 PMSQL Server에서 날짜/시간 비교
날짜/시간 값을 날짜만 비교하는 경우 예상치 못한 결과가 나올 수 있습니다. 이는 datetime 데이터 유형에 날짜 및 시간 구성요소가 모두 포함되기 때문입니다. 예를 들어 datetime 유형의 DateCreated 열이 있는 사용자 테이블이 있는 경우 다음 쿼리:
Select * from [User] U where U.DateCreated = '2014-02-07'
는 사용자가 2014-02-07 12시에 생성되었더라도 어떤 레코드도 반환하지 않습니다. :30:47.220.
날짜만 사용하여 날짜/시간을 정확하게 비교하려면 다음을 사용하세요. 방법:
Select * from [User] U where U.DateCreated >= '2014-02-07' and U.DateCreated < dateadd(day,1,'2014-02-07')
이 쿼리는 SARGable입니다. 즉, DateCreated 열의 인덱스를 사용할 수 있습니다.
함수를 사용하지 않는 이유는 무엇입니까?
CONVERT와 같은 함수를 사용하여 날짜/시간에서 날짜 구성 요소를 추출하고 싶을 수도 있습니다. 그러나 이는 권장되지 않습니다. WHERE 절 또는 조인 조건에서 함수 사용:
- 필드에서 인덱스를 사용하는 최적화 프로그램의 기능을 제거합니다
- 데이터의 각 행에 불필요한 계산을 추가합니다
피하기 BETWEEN
날짜 및 시간 범위를 다룰 때는 BETWEEN도 피해야 합니다. 대신 다음 형식을 사용하세요.
WHERE col >= '20120101' AND col < '20120201'
이 형식은 시간 부분에 관계없이 모든 데이터 유형 및 정밀도와 호환됩니다.
위 내용은 SQL Server에서 DATETIME과 DATE 값을 올바르게 비교하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

일반적인 취약점 (SQL 주입, 무차별 적 공격)에 대해 MySQL을 어떻게 보호합니까?
