>데이터 베이스 >MySQL 튜토리얼 >SQL Server에서 DATETIME 값의 시간 부분만 효율적으로 비교하려면 어떻게 해야 합니까?

SQL Server에서 DATETIME 값의 시간 부분만 효율적으로 비교하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-26 01:08:09299검색

How Can I Efficiently Compare Only the Time Portion of DATETIME Values in SQL Server?

SQL Server의 시간 값 비교

날짜/시간 필드에 저장된 시간 값을 비교할 때 날짜 구성 요소를 사용해야 하는지 여부를 고려하는 것이 중요합니다. 비교에 포함됩니다. 제공된 시나리오에서 사용자는 날짜를 제외하고 시간 부분만 비교하는 것을 목표로 합니다.

시간 값을 문자열로 변환하기 위해 CONVERT 함수를 사용하여 제안된 쿼리는 작동할 수 있지만 비효율적일 수 있습니다. 보다 최적의 솔루션은 SQL Server에서 날짜 시간 값의 내부 부동 소수점 표현을 활용하는 것입니다.

시간 비교를 효율적으로 수행하기 위해 다음을 수행할 수 있습니다.

  1. 날짜 시간을 변환합니다. CAST 함수를 사용하여 부동 소수점 값을 뺍니다.
  2. MOD를 사용하여 각 부동 소수점(시간 구성 요소)의 소수 부분을 뺍니다. 연산자입니다.

예를 들어 @first 및 @second라는 두 개의 날짜 시간 값이 있는 경우:

DECLARE @first DATETIME = '2009-04-30 19:47:16.123';
DECLARE @second DATETIME = '2009-04-10 19:47:16.123';

SELECT (
    CAST(@first AS FLOAT) - FLOOR(CAST(@first AS FLOAT))
) - (
    CAST(@second AS FLOAT) - FLOOR(CAST(@second AS FLOAT))
) AS Difference;

이 접근 방식은 날짜 구성 요소를 포함하지 않고 시간 값을 직접 비교하여 정확하고 효율적인 결과를 제공합니다. 결과입니다.

위 내용은 SQL Server에서 DATETIME 값의 시간 부분만 효율적으로 비교하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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