11

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

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

2 回答 2

31
SELECT CASE WHEN [Option] IN (1, 3, 99) THEN 'Wrong option' ELSE 'You go' END
于 2010-01-05T04:31:38.973 回答
5

您可以使用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

...没有加入。

于 2010-01-05T04:38:24.640 回答