I have a stored procedure in SQL Server 2000 that performs a search based on parameter values. For one of the parameters passed in, I need a different WHERE
clause depending on its value - the problem is that the 3 values would be where MyColumn
我在SQL Server 2000中有一个基于参数值执行搜索的存储过程。对于传入的一个参数,我需要一个不同的WHERE子句,取决于它的值——问题是,3个值将是MyColumn所在的位置。
-
IS NULL
- 为空
IS NOT NULL
- 不是零
-
ANY VALUE (NULL AND NOT NULL)
(essentially noWHERE
clause) - 任何值(NULL和NOT NULL)(基本上没有WHERE子句)
I'm having some mental block in coming up with the correct syntax. Is this possible to do in one select statement without performing some IF @parameter BEGIN ... END
branching?
我在构思正确的语法时遇到了一些障碍。是否可以在一个select语句中执行,而不执行IF @parameter BEGIN…分支?
6 个解决方案
#1
39
Here is how you can solve this using a single WHERE
clause:
以下是使用WHERE子句解决这个问题的方法:
WHERE (@myParm = value1 AND MyColumn IS NULL)
OR (@myParm = value2 AND MyColumn IS NOT NULL)
OR (@myParm = value3)
A naïve usage of the CASE statement does not work, by this I mean the following:
对案例陈述的幼稚用法不起作用,我的意思是:
SELECT Field1, Field2 FROM MyTable
WHERE CASE @myParam
WHEN value1 THEN MyColumn IS NULL
WHEN value2 THEN MyColumn IS NOT NULL
WHEN value3 THEN TRUE
END
It is possible to solve this using a case statement, see onedaywhen's answer
使用case语句解决这个问题是可能的,参见onedaywhen的答案
#2
12
You could just do something like this:
你可以这样做:
SELECT *
FROM foo
WHERE (@param = 0 AND MyColumn IS NULL)
OR (@param = 1 AND MyColumn IS NOT NULL)
OR (@param = 2)
Something like that.
就像这样。
#3
10
This is how it can be done using CASE
:
这就是用CASE的方法:
DECLARE @myParam INT;
SET @myParam = 1;
SELECT *
FROM MyTable
WHERE 'T' = CASE @myParam
WHEN 1 THEN
CASE WHEN MyColumn IS NULL THEN 'T' END
WHEN 2 THEN
CASE WHEN MyColumn IS NOT NULL THEN 'T' END
WHEN 3 THEN 'T' END;
#4
9
WHERE MyColumn = COALESCE(@value,MyColumn)
-
If
@value
isNULL
, it will compareMyColumn
to itself, ignoring@value = no where
clause.如果@value为NULL,它会将MyColumn与自身进行比较,忽略@value = no where子句。
-
IF
@value
has a value (NOT NULL
) it will compareMyColumn
to@value
.如果@value有一个值(非NULL),它会将MyColumn与@value进行比较。
Reference: COALESCE (Transact-SQL).
参考:合并(transact - sql)。
#5
5
An other way of CASE:
另一种情况:
SELECT *
FROM MyTable
WHERE 1 = CASE WHEN @myParm = value1 AND MyColumn IS NULL THEN 1
WHEN @myParm = value2 AND MyColumn IS NOT NULL THEN 1
WHEN @myParm = value3 THEN 1
END
#6
0
I've had success with this solution. It's almost like Patrick's, with a little twist. You can use these expressions separately or in sequence. If the parameter is blank, it will be ignored and all values for the column that your searching will be displayed, including NULLS.
我已经成功地解决了这个问题。有点像帕特里克的,有点扭曲。您可以单独或按顺序使用这些表达式。如果参数是空的,那么将会忽略它,并且将显示您搜索的列的所有值,包括NULLS。
SELECT * FROM MyTable
WHERE
--check to see if @param1 exists, if @param1 is blank, return all
--records excluding filters below
(Col1 LIKE '%' + @param1 + '%' OR @param1 = '')
AND
--where you want to search multiple columns using the same parameter
--enclose the first 'OR' expression in braces and enclose the entire
--expression
((Col2 LIKE '%' + @searchString + '%' OR Col3 LIKE '%' + @searchString + '%') OR @searchString = '')
AND
--if your search requires a date you could do the following
(Cast(DateCol AS DATE) BETWEEN CAST(@dateParam AS Date) AND CAST(GETDATE() AS DATE) OR @dateParam = '')
#1
39
Here is how you can solve this using a single WHERE
clause:
以下是使用WHERE子句解决这个问题的方法:
WHERE (@myParm = value1 AND MyColumn IS NULL)
OR (@myParm = value2 AND MyColumn IS NOT NULL)
OR (@myParm = value3)
A naïve usage of the CASE statement does not work, by this I mean the following:
对案例陈述的幼稚用法不起作用,我的意思是:
SELECT Field1, Field2 FROM MyTable
WHERE CASE @myParam
WHEN value1 THEN MyColumn IS NULL
WHEN value2 THEN MyColumn IS NOT NULL
WHEN value3 THEN TRUE
END
It is possible to solve this using a case statement, see onedaywhen's answer
使用case语句解决这个问题是可能的,参见onedaywhen的答案
#2
12
You could just do something like this:
你可以这样做:
SELECT *
FROM foo
WHERE (@param = 0 AND MyColumn IS NULL)
OR (@param = 1 AND MyColumn IS NOT NULL)
OR (@param = 2)
Something like that.
就像这样。
#3
10
This is how it can be done using CASE
:
这就是用CASE的方法:
DECLARE @myParam INT;
SET @myParam = 1;
SELECT *
FROM MyTable
WHERE 'T' = CASE @myParam
WHEN 1 THEN
CASE WHEN MyColumn IS NULL THEN 'T' END
WHEN 2 THEN
CASE WHEN MyColumn IS NOT NULL THEN 'T' END
WHEN 3 THEN 'T' END;
#4
9
WHERE MyColumn = COALESCE(@value,MyColumn)
-
If
@value
isNULL
, it will compareMyColumn
to itself, ignoring@value = no where
clause.如果@value为NULL,它会将MyColumn与自身进行比较,忽略@value = no where子句。
-
IF
@value
has a value (NOT NULL
) it will compareMyColumn
to@value
.如果@value有一个值(非NULL),它会将MyColumn与@value进行比较。
Reference: COALESCE (Transact-SQL).
参考:合并(transact - sql)。
#5
5
An other way of CASE:
另一种情况:
SELECT *
FROM MyTable
WHERE 1 = CASE WHEN @myParm = value1 AND MyColumn IS NULL THEN 1
WHEN @myParm = value2 AND MyColumn IS NOT NULL THEN 1
WHEN @myParm = value3 THEN 1
END
#6
0
I've had success with this solution. It's almost like Patrick's, with a little twist. You can use these expressions separately or in sequence. If the parameter is blank, it will be ignored and all values for the column that your searching will be displayed, including NULLS.
我已经成功地解决了这个问题。有点像帕特里克的,有点扭曲。您可以单独或按顺序使用这些表达式。如果参数是空的,那么将会忽略它,并且将显示您搜索的列的所有值,包括NULLS。
SELECT * FROM MyTable
WHERE
--check to see if @param1 exists, if @param1 is blank, return all
--records excluding filters below
(Col1 LIKE '%' + @param1 + '%' OR @param1 = '')
AND
--where you want to search multiple columns using the same parameter
--enclose the first 'OR' expression in braces and enclose the entire
--expression
((Col2 LIKE '%' + @searchString + '%' OR Col3 LIKE '%' + @searchString + '%') OR @searchString = '')
AND
--if your search requires a date you could do the following
(Cast(DateCol AS DATE) BETWEEN CAST(@dateParam AS Date) AND CAST(GETDATE() AS DATE) OR @dateParam = '')