What is the optimal way to compare dates in Microsoft SQL server?

前端 未结 4 1352
别跟我提以往
别跟我提以往 2020-12-25 11:27

I have a SQL datetime field in a very large table. It\'s indexed and needs to be queried.

The problem is that SQL always stores the time component (even

相关标签:
4条回答
  • 2020-12-25 12:01

    You could add a calculated column that includes only the date without the time. Between the two options, I'd go with the BETWEEN operator because it's 'cleaner' to me and should make better use of indexes. Comparing execution plans would seem to indicate that BETWEEN would be faster; however, in actual testing they performed the same.

    0 讨论(0)
  • 2020-12-25 12:08

    Get items when the date is between fromdate and toDate.

    where convert(date, fromdate, 103 ) <= '2016-07-26' and convert(date, toDate, 103) >= '2016-07-26'

    0 讨论(0)
  • 2020-12-25 12:15

    Converting to a DATE or using an open-ended date range in any case will yield the best performance. FYI, convert to date using an index are the best performers. More testing a different techniques in article: What is the most efficient way to trim time from datetime? Posted by Aaron Bertrand

    From that article:

    DECLARE @dateVar datetime = '19700204';
    
    -- Quickest when there is an index on t.[DateColumn], 
    -- because CONVERT can still use the index.
    SELECT t.[DateColumn]
    FROM MyTable t
    WHERE = CONVERT(DATE, t.[DateColumn]) = CONVERT(DATE, @dateVar);
    
    -- Quicker when there is no index on t.[DateColumn]
    DECLARE @dateEnd datetime = DATEADD(DAY, 1, @dateVar);
    SELECT t.[DateColumn] 
    FROM MyTable t
    WHERE t.[DateColumn] >= @dateVar AND 
          t.[DateColumn] < @dateEnd;
    

    Also from that article: using BETWEEN, DATEDIFF or CONVERT(CHAR(8)... are all slower.

    0 讨论(0)
  • 2020-12-25 12:19

    Here is an example:

    I've an Order table with a DateTime field called OrderDate. I want to retrieve all orders where the order date is equals to 01/01/2006. there are next ways to do it:

    1) WHERE DateDiff(dd, OrderDate, '01/01/2006') = 0
    2) WHERE Convert(varchar(20), OrderDate, 101) = '01/01/2006'
    3) WHERE Year(OrderDate) = 2006 AND Month(OrderDate) = 1 and Day(OrderDate)=1
    4) WHERE OrderDate LIKE '01/01/2006%'
    5) WHERE OrderDate >= '01/01/2006'  AND OrderDate < '01/02/2006'
    

    Is found here

    0 讨论(0)
提交回复
热议问题