SQL CASE [列] WHEN IN ('case1', 'case2') THEN 'oops'结尾?

发布于 2024-08-17 00:05:52 字数 129 浏览 2 评论 0原文

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

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

Is there a way to check a CASE when it's in an array:

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

乙白 2024-08-24 00:05:52
SELECT CASE WHEN [Option] IN (1, 3, 99) THEN 'Wrong option' ELSE 'You go' END
SELECT CASE WHEN [Option] IN (1, 3, 99) THEN 'Wrong option' ELSE 'You go' END
抽个烟儿 2024-08-24 00:05:52

您可以使用CASE WHEN <谓词>;那么<值> ... END 选项,而不是 CASE当<值>时那么<值> ...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

...没有联接。

You can use the CASE WHEN <predicate> THEN <value> ... END option, rather than the CASE <value> WHEN <value> THEN <value> ... END option.

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

... but if the values are in a table, you could just do an outer join (and

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

, or

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

...without a join.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文