SQL Server: Index columns used in like?

后端 未结 3 418
春和景丽
春和景丽 2020-11-28 09:28

Is it a good idea to index varchar columns only used in LIKE opertations? From what I can read from query analytics I get from the following query:

SELECT *          


        
相关标签:
3条回答
  • 2020-11-28 09:33

    Given the data 'abcdefg'

    WHERE Column1 LIKE '%cde%'  --can't use an index
    
    WHERE Column1 LIKE 'abc%' --can use an index
    
    WHERE Column1 Like '%defg' --can't use an index, but see note below
    

    Note: If you have important queries that require '%defg', you could use a persistent computed column where you REVERSE() the column and then index it. Your can then query on:

    WHERE Column1Reverse Like REVERSE('defg')+'%' --can use the persistent computed column's index
    
    0 讨论(0)
  • 2020-11-28 09:43

    To answer the metrics part of your question: The type of index/table scan/seek being performed is a good indicator for knowing if an index is being (properly) used. It's usually shown topmost in the query plan analyzer.

    The following scan/seek types are sorted from worst (top) to best (bottom):

    • Table Scan
    • Clustered Index Scan
    • Index Scan
    • Clustered Index Seek
    • Index Seek

    As a rule of thumb, you would normally try to get seeks over scans whenever possible. As always, there are exceptions depending on table size, queried columns, etc. I recommend doing a search on StackOverflow for "scan seek index", and you'll get a lot of good information about this subject.

    0 讨论(0)
  • 2020-11-28 09:48

    In my experience the first %-sign will make any index useless, but one at the end will use the index.

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