How can I force a query to not use a index on a given table?

后端 未结 3 711
鱼传尺愫
鱼传尺愫 2020-12-24 11:54

I\'m currently doing some testing to determine the performance implications of including an index on a given column in SQL Server 2005.

The test data set I\'m using

相关标签:
3条回答
  • 2020-12-24 12:31

    I'm working with all different kinds of DBs and can never remember the specific hint when I need it. Therefore I'm using a pure SQL approach that (currently) works with all the DBs that cross my way.

    The idea is just to make it impossible for the DB to use the specific index by obfuscating the respective expression in the SQL. E.g. when a where clause makes the database believe it's best resolved using an index, but it isn't.

    SELECT *
    FROM MyTable
    WHERE MyIndexedColumn + 0 = 0
    

    Similarly, you can add an empty string to a string value. Current optimizers do no resolve such expressions can cannot use an index on (MyIndexedColumn).

    This is actually an anti-pattern I described in my book. Here are some on page about math in SQL

    It's definitively good enough for ad-hoc testing. In production code, hints are more expressive of course!

    0 讨论(0)
  • 2020-12-24 12:44
    SELECT *
    FROM MyTable WITH (INDEX(0))
    WHERE MyIndexedColumn = 0
    

    Query would normally use the index on MyIndexedColumn, but due to the table hint, it will instead tablescan.


    SELECT *
    FROM MyTable WITH (INDEX(IndexName))
    WHERE MyIndexedColumn = 0
    

    Query would normally use the index on MyIndexedColumn, but due to the table hint, it will instead use the index named IndexName.

    0 讨论(0)
  • 2020-12-24 12:47

    You can disable the index you don't want to use in the same transaction that you're running the test code in, just be sure to rollback the transaction at the end. This ensures the test code won't use the index but prevents the index from actually being disabled.

    BEGIN TRANSACTION
    
        ALTER INDEX [MyIndex] ON MyTable DISABLE;
    
        EXEC TestCode;
    
    ROLLBACK
    

    This works better if you've got a complex case where your test code uses a number of indexes at different times and you want to test if the addition of a new one would improve things.

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