首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >成对比较

成对比较
EN

Stack Overflow用户
提问于 2012-12-26 10:06:35
回答 2查看 1.6K关注 0票数 0

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

如果@p的值为1,则不筛选表[a]中的数据;如果@p的值为0,则根据表[b]上的数据筛选表[b]中的数据。但是必须使用配对比较来比较数据。

如果SQL Server支持成对比较,我可以使用以下语法执行此操作

代码语言:javascript
复制
SELECT
    *
FROM
    a
WHERE
    (@p = 1) or ((a.col1, a.col2) in (SELECT col1, col2 FROM b))

但是,不幸的是,SQL Server不支持成对比较。

我也可以使用if语句来做这件事。

代码语言:javascript
复制
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

但是,它使我的存储过程太长。有没有其他的变通方法呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-12-26 13:55:52

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

代码语言:javascript
复制
SELECT columnlist
FROM a
WHERE @p=1 OR EXISTS (SELECT * FROM b WHERE a.col1=b.col1 AND a.col2=b.col2)
票数 2
EN

Stack Overflow用户

发布于 2012-12-27 00:19:38

可以使用EXISTS重写它:

代码语言:javascript
复制
SELECT
*
FROM
a
WHERE
(@p = 1) or EXISTS(SELECT 1 FROM b where b.col1=a.col1 and b.col2=a.col2)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14035324

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档