SQL CASE [Column] WHEN IN('case 1','case 2')那么'oops'END?

时间:2010-01-05 04:23:02

标签: sql-server syntax case sql

有没有办法在数组中检查CASE:

SELECT CASE [Option] WHEN IN (1, 3, 99) THEN 'Wrong option' ELSE 'You go!' END

2 个答案:

答案 0 :(得分:20)

SELECT CASE WHEN [Option] IN (1, 3, 99) THEN 'Wrong option' ELSE 'You go' END

答案 1 :(得分:4)

您可以使用CASE WHEN <predicate> THEN <value> ... END选项,而不是CASE <value> WHEN <value> THEN <value> ... END选项。

SELECT CASE WHEN [Option] IN (1, 3, 99) THEN 'Wrong option' ELSE 'You go!' END

...但如果值在表中,您可以只进行外连接(和

CASE WHEN t.Value IS NULL THEN 'Not in list' ELSE 'In list' END

,或

CASE WHEN EXISTS (SELECT * FROM yourTable t WHERE t.value = [Option]) THEN 'Bad' ELSE 'Ok' END

......没有加入。