Ignoring a NULL parameter in T-SQL

后端 未结 10 883
余生分开走
余生分开走 2020-12-03 01:40

I want to be able to pass in a list of parameters, and ignore the ones which are NULL. So that the query is in effect pretending that the filter isn\'t there and ignoring it

相关标签:
10条回答
  • 2020-12-03 02:00

    Once you get more than a couple of these, then yes: it starts to get pretty slow. In such cases, I tend to use generated TSQL - i.e.

    DECLARE @sql nvarchar(4000)
    SET @sql = /* core query */
    
    IF @name IS NOT NULL
        SET @sql = @sql + ' AND foo.Name = @name'
    
    IF @dob IS NOT NULL
        SET @sql = @sql + ' AND foo.DOB = @dob'
    
    // etc
    
    EXEC sp_ExecuteSQL @sql, N'@name varchar(100), @dob datetime',
            @name, @dob
    

    etc

    Note that sp_ExecuteSQL caches query-plans, so any queries with the same args can potentially re-use the plan.

    The downside is that unless you sign the SPROC, the caller needs SELECT permissions on the table (not just EXEC permissions on the SPROC).

    0 讨论(0)
  • 2020-12-03 02:06

    I would handle it this way.

    WHERE Thing = ISNULL(@Thing, Thing)
    

    If you're just using the parameter as a filter on the where clause, this will work very well. It will ignore the parameter if it is null.

    0 讨论(0)
  • 2020-12-03 02:08

    I'm not sure if it is the 'optimal' way, but this is exactly what I do in my stored procedures for the same purposes. My gut feeling is that this is faster than a dynamically created query purely from an execution plan standpoint. The other option is to create a query for each combination of these "flags" that you are passing in, but that really isn't that scalable.

    0 讨论(0)
  • 2020-12-03 02:10

    I generally use

    WHERE (id = @id OR @id IS NULL)
    AND (num = @num OR @num IS NULL)
    

    etc.

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