是否可以根据mssql中case select的结果从不同的表中进行选择?
发布于 2010-11-18 02:22:57
Select
ConditionalValue = (Case When something Then Table1.Value Else Table2.Value End),
...
From
Table1
...
Table2更多细节,我们需要更多细节。
发布于 2010-11-18 02:24:10
您可以构建动态SQL,然后执行它。
DECLARE @SQL nvarchar(1000)
SET @SQL = 'SELECT * FROM '
CASE Condition
WHEN 1 THEN @SQL = @SQL + 'TABLE '
ELSE @SQL = @SQL + 'TABLE1 '
END
EXEC(@SQL)发布于 2010-11-18 02:24:37
如果这两个表有某种一对一的关系,您可以连接它们,然后根据列的case操作符从A或B返回一列。除此之外,您可以使用过程代码(TransactSQL)来测试确定要从中选择的表的条件,并调用一个或另一个select语句,这些语句返回相同的列,但每个语句都指向一个表。如果这些表具有类似的模式,并且您正在从程序中查询它们,则可以根据您希望检查的条件来操作命令的字符串表示。最后,您可以联合两个查询,每个查询指向一个不同的表,每个子查询上都有一个WHERE子句,用于计算条件,如果为false,则不返回任何行。
https://stackoverflow.com/questions/4207714
复制相似问题