What's a good way to check if two datetimes are on the same calendar day in TSQL?

前端 未结 10 1439
小鲜肉
小鲜肉 2021-02-12 02:15

Here is the issue I am having: I have a large query that needs to compare datetimes in the where clause to see if two dates are on the same day. My current solution, which suck

10条回答
  •  孤独总比滥情好
    2021-02-12 03:19

    Eric Z Beard:

    I do store all dates in GMT. Here's the use case: something happened at 11:00 PM EST on the 1st, which is the 2nd GMT. I want to see activity for the 1st, and I am in EST so I will want to see the 11PM activity. If I just compared raw GMT datetimes, I would miss things. Each row in the report can represent an activity from a different time zone.

    Right, but when you say you're interested in activity for Jan 1st 2008 EST:

    SELECT @activityDateMidnight = '1/1/2008', @activityDateTZ = 'EST'
    

    you just need to convert that to GMT (I'm ignoring the complication of querying for the day before EST goes to EDT, or vice versa):

    Table: TimeZone
    Fields: TimeZone, Offset
    Values: EST, -4
    
    --Multiply by -1, since we're converting EST to GMT.
    --Offsets are to go from GMT to EST.
    SELECT @activityGmtBegin = DATEADD(hh, Offset * -1, @activityDateMidnight)
    FROM TimeZone
    WHERE TimeZone = @activityDateTZ
    

    which should give you '1/1/2008 4:00 AM'. Then, you can just search in GMT:

    SELECT * FROM EventTable
    WHERE 
       EventTime >= @activityGmtBegin --1/1/2008 4:00 AM
       AND EventTime < (@activityGmtBegin + 1) --1/2/2008 4:00 AM
    

    The event in question is stored with a GMT EventTime of 1/2/2008 3:00 AM. You don't even need the TimeZone in the EventTable (for this purpose, at least).

    Since EventTime is not in a function, this is a straight index scan - which should be pretty efficient. Make EventTime your clustered index, and it'll fly. ;)

    Personally, I'd have the app convert the search time into GMT before running the query.

提交回复
热议问题