집 >데이터 베이스 >MySQL 튜토리얼 >T-SQL 시간 값을 가장 가까운 15분 간격으로 효율적으로 반올림하는 방법은 무엇입니까?
정확한 계산: T-SQL 시간 값을 가장 가까운 15분 간격으로 반올림
T-SQL에서 시간 기반 데이터를 처리할 때 값을 특정 시간 간격으로 반올림해야 하는 경우가 많습니다. 일반적인 요구 사항은 HH:MM 값을 가장 가까운 15분 간격으로 반올림하는 것입니다.
효율적인 반올림 방법
복잡한 UDF 또는 CASE 문에 의존하지 않고 대신 DATEADD 및 DATEDIFF 함수를 활용하여 시간 값을 가장 가까운 15분 간격으로 반올림하는 효율적인 방법입니다. 이 방법에는 다음이 포함됩니다.
예
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!