집 >데이터 베이스 >MySQL 튜토리얼 >MS SQL Server의 `BETWEEN` 연산자는 포괄적인가요, 아니면 배타적인가요?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!