Compare performance difference of T-SQL Between and '<' '>' operator?

后端 未结 7 1183
情歌与酒
情歌与酒 2020-12-31 05:02

I\'ve tried searching through search engines,MSDN,etc. but can\'t anything. Sorry if this has been asked before. Is there any performance difference between using the T-SQL

相关标签:
7条回答
  • 2020-12-31 05:28

    In more complex queries where you can't know your min or max value that you'll be going to compare to beforehand, then using BETWEEN is almost equivalent to using the >= and <= operators.

    But when you know beforehand exactly what your min and max values are, it is cheaper not to use the BETWEEN operator and instead compare the wanted results to 1 number below the min and 1 number above the max.

    SELECT n.Number FROM dbo.Numbers AS n
    WHERE n.Number BETWEEN 1 AND 100
    

    is almost equivalent to:

    SELECT n.Number FROM dbo.Numbers AS n
    WHERE n.Number >= 1 AND n.Number <= 100
    

    where each row is compared separately for >, < and for =.

    rather do:

    SELECT n.Number FROM dbo.Numbers AS n
    WHERE n.Number > 0 AND n.Number < 101
    

    where each row is compared only for > and <.

    0 讨论(0)
  • 2020-12-31 05:31

    You can check this easily enough by checking the query plans in both situations. There is no difference of which I am aware. There is a logical difference though between BETWEEN and "<" and ">"... BETWEEN is inclusive. It's equivalent to "<=" and "=>".

    0 讨论(0)
  • 2020-12-31 05:33

    The query engine converts between into >= and <= (take a look at the query plan) so in practise they're identical and in theory >= <= is faster because the engine won't have to translate. Good luck noticing a difference though.

    I use between anyway, I find it reads easier

    Very complex queries/nested views with numerous between comparisons might benefit from changing into >= <= as this might potentially prevent optimisation timeouts by reducing the time spent on refactoring the query (just a theory, untested by me & I've never noticed it)

    0 讨论(0)
  • 2020-12-31 05:38

    Love when folks give code to do your own testing, you need to do a larger subset / repeated test to account for indexes being loaded into memory, etc... before jumping to conclusions though. Here is the same code with a larger table and 10 iterations

    DECLARE
        @Startdatetime datetime ,
        @Diff int = 0 ,
        @Addrowcount int = 1000 ,
        @ptr int = 1;
    
    
    SET NOCOUNT ON;
    
    --Create a tempory table to perform our tests on
    DROP TABLE dbo.perftest
    
    CREATE TABLE dbo.perftest( id int NOT NULL
                                           IDENTITY(1 , 1)
                                           PRIMARY KEY ,
                               mytext nvarchar( 50 )NOT NULL );
    
    --Now add some sample rows
    
    SET @Addrowcount = 20000;
    
    WHILE(@Addrowcount > 0)
    
        BEGIN
    
            INSERT INTO dbo.perftest( mytext )
            VALUES( 'thetext' );
    
            SET @Addrowcount = @Addrowcount - 1;
    
        END;
    
    WHILE @ptr < 10 -- do this a few times to account for indexes being loaded into memory
    
    BEGIN
    
        SELECT @Startdatetime = GETDATE();
    
        -- do method 1 here
    
        SELECT mytext
          FROM dbo.perftest
          WHERE(id >= (100 + (@ptr * 1000)))
           AND (id <= (500 + (@ptr * 1000)));
    
        --end method1
    
        SELECT @Diff = DATEDIFF( millisecond , @Startdatetime , GETDATE());
    
        PRINT ':Method 1: ' + CAST(@Diff AS nvarchar( 20 )) + ' ms';
    
        --reset start time
    
        SELECT @Startdatetime = GETDATE();
    
        --do method2 here
    
        SELECT mytext
          FROM dbo.perftest
          WHERE id BETWEEN (300 + (@ptr * 1000))
            AND (800 + (@ptr * 1000));
    
        --end method2
    
        SELECT @Diff = DATEDIFF( millisecond , @Startdatetime , GETDATE());
    
        PRINT ':Method 2: ' + CAST(@Diff AS nvarchar( 20 )) + ' ms';
    
        SET @ptr = @ptr + 1
    
    END
    

    Gives you a very different set of results:

    --Method 1    -- 10 ms
    --Method 2    -- 33 ms
    --Method 1    -- 40 ms
    --Method 2    -- 26 ms
    --Method 1    -- 23 ms
    --Method 2    -- 23 ms
    --Method 1    -- 13 ms
    --Method 2    -- 16 ms
    --Method 1    -- 13 ms
    --Method 2    -- 20 ms
    --Method 1    -- 6 ms
    --Method 2    -- 16 ms
    --Method 1    -- 26 ms
    --Method 2    -- 16 ms
    --Method 1    -- 13 ms
    --Method 2    -- 13 ms
    --Method 1    -- 16 ms
    --Method 2    -- 13 ms
    

    I would say from this (still pretty unscientific) test, not much difference either way.

    0 讨论(0)
  • 2020-12-31 05:42

    I was also interested in whether there is a performance difference when I used (>= and <=) compared to using the between keyword. (I come from a dotnet background and like the >= style operators).
    Here is the script I used:

    DECLARE
        @Startdatetime datetime ,
        @Diff int = 0 ,
        @Addrowcount int = 1000;
    
    SET NOCOUNT ON;
    
    --Create a tempory table to perform our tests on
    
    CREATE TABLE dbo.perftest( id smallint NOT NULL
                                           IDENTITY(1 , 1)
                                           PRIMARY KEY ,
                               mytext nvarchar( 50 )NOT NULL );
    
    --Now add some sample rows
    
    SET @Addrowcount = 1000;
    
    WHILE(@Addrowcount > 0)
    
        BEGIN
    
            INSERT INTO dbo.perftest( mytext )
            VALUES( 'thetext' );
    
            SET @Addrowcount = @Addrowcount - 1;
    
        END;
    
    SELECT @Startdatetime = GETDATE();
    
    -- do method 1 here
    
    SELECT mytext
      FROM dbo.perftest
      WHERE(id >= 100)
       AND (id <= 900);
    
    --end method1
    
    SELECT @Diff = DATEDIFF( millisecond , @Startdatetime , GETDATE());
    
    PRINT ':Method 1: ' + CAST(@Diff AS nvarchar( 20 )) + ' ms';
    
    --reset start time
    
    SELECT @Startdatetime = GETDATE();
    
    --do method2 here
    
    SELECT mytext
      FROM dbo.perftest
      WHERE id BETWEEN 100
        AND 900;
    
    --end method2
    
    SELECT @Diff = DATEDIFF( millisecond , @Startdatetime , GETDATE());
    
    PRINT ':Method 2: ' + CAST(@Diff AS nvarchar( 20 )) + ' ms';
    

    The results were:

    Method 1: 140 ms

    Method 2: 70 ms

    So it appears that performance is improved by using between.

    0 讨论(0)
  • 2020-12-31 05:46

    The two operators that are being compared to one another here are fundamentally different and hence why the execution plans that are generated are also likely to be different (although not guaranteed).

    The determining factor is the data distribution (selectivity) of the column that the comparison operators are applied to. This along with Statistics will dictate whether or not an index is or is not used etc.

    Hope this makes sense.

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