是否可以在t-sql查询中的FROM子句中使用CASE? 例如:FROM子句中的CASE
SELECT *
FROM CASE
WHEN column_ = 'firstColumn'
THEN table_ t, firstTable fT
ELSE table_ t, secondTable sT
是否可以在t-sql查询中的FROM子句中使用CASE? 例如:FROM子句中的CASE
SELECT *
FROM CASE
WHEN column_ = 'firstColumn'
THEN table_ t, firstTable fT
ELSE table_ t, secondTable sT
谢谢大家对您的输入。我真的结束了类似于Quassnoi的建议:
SELECT *
FROM table_ t, firstTable fT
UNION
SELECT *
FROM table_ t, secondTable sT
我不知道我在想什么。我应该早点明白这一点。
SELECT *
FROM mytable t
CROSS APPLY
(
SELECT *
FROM firstTable ft
WHERE t.column = 'firstColumn'
AND ft.id = t.joincolumn
UNION ALL
SELECT *
FROM secondTable st
WHERE (t.column <> 'firstColumn' OR t.column IS NULL)
AND st.id = t.joincolumn
) q
我站好了。 :-) +1,但我很高兴我不会和你一起工作,如果你做这样的事情。 ;-) –
@KenWhite:与知道“CROSS APPLY”的人一起工作有什么不好? :) – Quassnoi
只要你知道如何使用它*非常*明智地知道它没有错。 :-) –
不,它不是! – Mithrandir