>데이터 베이스 >MySQL 튜토리얼 >T-SQL 시간 값을 가장 가까운 15분 간격으로 효율적으로 반올림하는 방법은 무엇입니까?

T-SQL 시간 값을 가장 가까운 15분 간격으로 효율적으로 반올림하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-10 13:56:42657검색

How to Efficiently Round T-SQL Time Values to the Nearest 15-Minute Interval?

정확한 계산: T-SQL 시간 값을 가장 가까운 15분 간격으로 반올림

T-SQL에서 시간 기반 데이터를 처리할 때 값을 특정 시간 간격으로 반올림해야 하는 경우가 많습니다. 일반적인 요구 사항은 HH:MM 값을 가장 가까운 15분 간격으로 반올림하는 것입니다.

효율적인 반올림 방법

복잡한 UDF 또는 CASE 문에 의존하지 않고 대신 DATEADD 및 DATEDIFF 함수를 활용하여 시간 값을 가장 가까운 15분 간격으로 반올림하는 효율적인 방법입니다. 이 방법에는 다음이 포함됩니다.

  • DATEDIFF를 사용하여 주어진 시간 값과 영(0) 날짜 간의 차이를 계산합니다.
  • 정수 나누기를 사용하여 차이를 15로 나누어 15분 간격이 몇 번 경과했는지 확인합니다.
  • DATEADD를 사용하여 결과에 15를 곱하고 0 날짜에 적절한 분 수를 더합니다.

CONVERT, DATEADD 및 DATEDIFF 함수를 사용한 특정 계산 요구 사항에 이 방법을 적용하면 다음 쿼리를 얻게 됩니다.

<code class="language-sql">SELECT DATEADD(MINUTE, ROUND(DATEDIFF(MINUTE, 0, CONVERT(CHAR(8), DATEADD(n, SUM(DATEDIFF(n, starttime, stoptime)), 0), 108)) / 15.0, 0) * 15, 0)</code>

이 계산은 HH:MM 시간 값을 가장 가까운 15분 간격으로 정확하게 반올림하여 00:08:00과 같은 값이 00:15:00이 되고 00:07:00이 00:00:00이 되도록 합니다.

다른 방법

DATEADD 및 DATEDIFF 방법은 효율적이고 정확하지만 T-SQL에서 시간 값을 반올림하는 데 고려할 수 있는 몇 가지 다른 방법이 있습니다.

  • ROUND 함수를 사용하고 간격을 지정하세요.

    <code class="language-sql">  ROUND(time_value, 15)</code>
  • SQL Server 2012의 FLOOR 함수 사용:

    <code class="language-sql">  FLOOR(DATEADD(MINUTE, time_value, 0))</code>

위 내용은 T-SQL 시간 값을 가장 가까운 15분 간격으로 효율적으로 반올림하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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