Have you ever needed to do a quick time calculations of the amount of hours/minutes/seconds that have passed? Suppose you needed to get the total number of minutes that have passed for a total time of ‘2:24’.
There are some easy ways to do this, and the normal calculation that you might make is to multiple hours by 60 and then add minutes, so something like:
DECLARE @t TIME, @n INT SELECT @t = '2:24' SELECT @n = DATEPART( hh, @t) * 60 + DATEPART(mi, @t) SELECT @n
That returns 144, which is the correct value (60 * 2 = 120, adding 24). However there’s an easier, and cleaner, way.
SELECT DATEDIFF(mi, 0, @t)
You can let SQL Server do the math, grabbing the DATEDIFF function and using 0 as a starting point.
Number of seconds in a day?
DECLARE @t TIME, @n INT, @d DATETIME SELECT @t = '11:59:59PM' SELECT DATEDIFF(ss, 0, @t) + 1
Filed under: Blog Tagged: syndicated, T-SQL