首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL案例选择

SQL案例选择
EN

Stack Overflow用户
提问于 2010-11-18 02:20:08
回答 4查看 557关注 0票数 2

是否可以根据mssql中case select的结果从不同的表中进行选择?

EN

回答 4

Stack Overflow用户

发布于 2010-11-18 02:22:57

代码语言:javascript
复制
Select
  ConditionalValue = (Case When something Then Table1.Value Else Table2.Value End),
  ...
From
  Table1
  ...
  Table2

更多细节,我们需要更多细节。

票数 4
EN

Stack Overflow用户

发布于 2010-11-18 02:24:10

您可以构建动态SQL,然后执行它。

代码语言:javascript
复制
DECLARE @SQL nvarchar(1000)

SET @SQL = 'SELECT * FROM '

CASE Condition
    WHEN 1 THEN @SQL = @SQL  + 'TABLE '
    ELSE @SQL = @SQL  + 'TABLE1 '
END

EXEC(@SQL)
票数 4
EN

Stack Overflow用户

发布于 2010-11-18 02:24:37

如果这两个表有某种一对一的关系,您可以连接它们,然后根据列的case操作符从A或B返回一列。除此之外,您可以使用过程代码(TransactSQL)来测试确定要从中选择的表的条件,并调用一个或另一个select语句,这些语句返回相同的列,但每个语句都指向一个表。如果这些表具有类似的模式,并且您正在从程序中查询它们,则可以根据您希望检查的条件来操作命令的字符串表示。最后,您可以联合两个查询,每个查询指向一个不同的表,每个子查询上都有一个WHERE子句,用于计算条件,如果为false,则不返回任何行。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4207714

复制
相关文章

相似问题

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