Alternative to using local variables in a where clause

后端 未结 4 1656
清歌不尽
清歌不尽 2021-01-24 07:24

I have a query that has a where clause built using a number of local variables, This however is painfully slow. Below is a rough example as I don\'t have access to the query cur

相关标签:
4条回答
  • 2021-01-24 07:38

    It gets messy and can lead to a new set of problems but you might want to evaluate converting this over to dynamic SQL. Basically you construct your where clause at run time based on which parameters actually have (non wildcard) values in them.

    This is one of the best dynamic SQL write-ups I have found: http://www.sommarskog.se/dynamic_sql.html

    And here is another where he specifically addresses dynamic where clauses: http://www.sommarskog.se/dyn-search-2005.html

    0 讨论(0)
  • 2021-01-24 07:39

    No.

    For constants, the optimizer can work out the best plan based on statistics for the given values.

    When you use variable you are forcing parameterization and the plan will be designed to be reusable for a wide range of values.

    In this case you can try OPTIMISE FOR UNKNOWN which may give better results. Or don't filter like this: use different queries for different permutations. Do you have LIKE too with leading wildcards?

    0 讨论(0)
  • 2021-01-24 07:51

    Using local variables at WHERE filter causes FULL TABLE SCAN. Because SS does not know the values of local variables at compile time. So it creates an execution plan for the largest scale that can be avaliable for the column.

    In order to prevent the performance problem, SS must know the values of the variables at compile time. Defining a SP, and passing these local varibles as a parameter is one of the solution of the problem. Another solution is, using sp_executesql and passing those local variables as a parameter again...

    Or you can add OPTION ( RECOMPILE ) at the end of your sql statement to make your local varibles be compiled. This will solve the performans problem.

    0 讨论(0)
  • 2021-01-24 07:56

    Optimise for unknown given by gbn may work in some cases, but in other cases, OPTION RECOMPILE may be a better choice.

    For simple queries on a dataset that varies between extremes, OPTION RECOMPILE gives you the best plan for each case, because it in effect plans out each query using static values (plan cost for each execution), but OPTIMISE FOR UNKNOWN causes a generic plan that may not be the best in any case, being average for all cases (cached plan).

    Sample usage

    select top 10 * from master..spt_values
    OPTION (RECOMPILE)
    

    There were some edge case bugs with OPTION RECOMPILE in SQL Server 2005, but it works fine in 2008.

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