Sql server 2008 成对比较

Sql server 2008 成对比较,sql-server-2008,Sql Server 2008,我想在SQL Server中基于参数@p执行一条语句,该参数在调用存储过程时被传递到存储过程中 如果@p的值为1,则不过滤表[a]中的数据,如果@p的值为0,则根据表[b]中的数据过滤表[a]中的数据。但数据必须使用成对比较进行比较 如果SQL Server支持成对比较,我可以使用以下语法来实现 SELECT * FROM a WHERE (@p = 1) or ((a.col1, a.col2) in (SELECT col1, col2 FROM b)) 但不幸的是

我想在SQL Server中基于参数
@p
执行一条语句,该参数在调用存储过程时被传递到存储过程中

如果
@p
的值为1,则不过滤表
[a]
中的数据,如果
@p
的值为0,则根据表
[b]
中的数据过滤表
[a]
中的数据。但数据必须使用成对比较进行比较

如果SQL Server支持成对比较,我可以使用以下语法来实现

SELECT
    *
FROM
    a
WHERE
    (@p = 1) or ((a.col1, a.col2) in (SELECT col1, col2 FROM b))
但不幸的是,SQLServer不支持成对比较

我也可以使用if语句来实现

if(@p=1)
begin
    SELECT
        *
    FROM
        a
end
else
begin
    SELECT
        *
    FROM
        a join b on a.col1=b.col1 and a.col2=b.col2
end

但是,它使我的存储过程太长。还有其他解决方法吗?

最简单的方法可能是使用EXISTS语法:

SELECT columnlist
FROM a
WHERE @p=1 OR EXISTS (SELECT * FROM b WHERE a.col1=b.col1 AND a.col2=b.col2)

最简单的方法可能是使用EXISTS语法:

SELECT columnlist
FROM a
WHERE @p=1 OR EXISTS (SELECT * FROM b WHERE a.col1=b.col1 AND a.col2=b.col2)

可以使用EXISTS将其改写如下:

SELECT
*
FROM
a
WHERE
(@p = 1) or EXISTS(SELECT 1 FROM b where b.col1=a.col1 and b.col2=a.col2)

可以使用EXISTS将其改写如下:

SELECT
*
FROM
a
WHERE
(@p = 1) or EXISTS(SELECT 1 FROM b where b.col1=a.col1 and b.col2=a.col2)