2012-05-31 93 views
2

是否可以在t-sql查询中的FROM子句中使用CASE? 例如:FROM子句中的CASE

SELECT * 
FROM CASE 
    WHEN column_ = 'firstColumn' 
     THEN table_ t, firstTable fT 
    ELSE table_ t, secondTable sT 
+0

不,它不是! – Mithrandir

回答

1

谢谢大家对您的输入。我真的结束了类似于Quassnoi的建议:

SELECT * 
FROM table_ t, firstTable fT 

UNION 

SELECT * 
FROM table_ t, secondTable sT 

我不知道我在想什么。我应该早点明白这一点。

3
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 
+0

我站好了。 :-) +1,但我很高兴我不会和你一起工作,如果你做这样的事情。 ;-) –

+0

@KenWhite:与知道“CROSS APPLY”的人一起工作有什么不好? :) – Quassnoi

+0

只要你知道如何使用它*非常*明智地知道它没有错。 :-) –