>데이터 베이스 >MySQL 튜토리얼 >MS SQL Server의 `BETWEEN` 연산자는 포괄적인가요, 아니면 배타적인가요?

MS SQL Server의 `BETWEEN` 연산자는 포괄적인가요, 아니면 배타적인가요?

DDD
DDD원래의
2024-12-27 21:41:14151검색

Is MS SQL Server's `BETWEEN` Operator Inclusive or Exclusive?

MS SQL Server의 "BETWEEN" 연산자를 사용한 포함 범위 검색

MS SQL Server의 "BETWEEN" 연산자를 사용할 때 다음 사항을 이해하는 것이 중요합니다. 범위 경계는 선택 기준에 포함되거나 제외됩니다.

구체적인 질문에 답하려면, "BETWEEN" 연산자가 포함됩니다. 즉, 기본적으로 하한 및 상한으로 지정된 값이 결과 집합에 포함됩니다. 제공된 예에서:

SELECT foo
FROM bar
WHERE foo BETWEEN 5 AND 10

쿼리는 "foo" 열의 값이 5와 10 사이(포함)인 모든 행을 선택합니다.

그러나 이 포괄적인 동작은 DateTimes로 작업할 때 주의 사항이 있을 수 있습니다. 기본적으로 날짜만 지정하면 SQL Server는 해당 날짜를 자정으로 처리합니다. 즉, 특정 날짜 내의 모든 값을 캡처하려면 종료 날짜에서 3밀리초를 빼야 자정 전 3밀리초 내의 데이터가 누락되지 않습니다.

예를 들어, 해당 날짜 내의 모든 값을 검색하려면 2016년 6월의 올바른 쿼리는 다음과 같습니다.

where myDateTime between '20160601' and DATEADD(millisecond, -3, '20160701')

이렇게 하면 6월 30일 자정 3밀리초 전.

대부분의 데이터 유형에 대해 "BETWEEN" 연산자가 포함되지만 예외가 있다는 점에 유의하는 것이 중요합니다. 예를 들어 "datetime2" 및 "datetimeoffset" 데이터 유형의 경우 일반적으로 ">=" 및 "<"를 사용하는 것이 좋습니다. 잠재적인 범위 잘림 문제를 방지하려면 "BETWEEN" 대신 연산자를 사용하세요.

위 내용은 MS SQL Server의 `BETWEEN` 연산자는 포괄적인가요, 아니면 배타적인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.