博客 sql示例:case when作为where 条件

sql示例:case when作为where 条件

   数栈君   发表于 2023-08-24 10:26  641  0

CASE WHEN语句的结果可以作为WHERE条件和其他条件一起使用,可以根据具体的需求来灵活组合。下面分别给出多个CASE WHEN语句在不同位置的SQL示例:

CASE WHEN语句在WHERE条件中作为条件之一

SELECT *
FROM table_name
WHERE
    CASE
        WHEN condition_1 THEN 1
        WHEN condition_2 THEN 1
        ELSE 0
    END = 1
    AND condition_3 = 'xxx';

上述代码中,CASE WHEN语句在WHERE条件中作为一个条件,其中condition_1和condition_2表示需要满足的条件。在WHERE条件中,将CASE WHEN语句的结果和1进行比较,如果相等则表示条件满足,即进行过滤。
2. CASE WHEN语句在SELECT语句中作为结果

SELECT
    column_1,
    column_2,
    CASE
        WHEN condition_1 THEN 'A'
        WHEN condition_2 THEN 'B'
        ELSE 'C'
    END AS result
FROM table_name
WHERE condition_3 = 'xxx';

上述代码中,CASE WHEN语句在SELECT语句中作为一个结果,其中condition_1和condition_2表示需要满足的条件。在SELECT语句中,根据条件的不同返回不同的结果,并将结果命名为result。
3. 多个CASE WHEN语句在WHERE条件中组合使用

SELECT *
FROM table_name
WHERE
    CASE
        WHEN condition_1 THEN 1
        ELSE 0
    END = 1
    AND (
        CASE
            WHEN condition_2 THEN 1
            ELSE 0
        END = 1 OR
        CASE
            WHEN condition_3 THEN 1
            ELSE 0
        END = 1
    );

上述代码中,使用了多个CASE WHEN语句在WHERE条件中进行组合,其中condition_1、condition_2和condition_3表示需要满足的条件。在WHERE条件中,使用AND和OR逻辑运算符将多个条件组合在一起,实现更加复杂的条件过滤。
需要注意的是,使用CASE WHEN语句进行条件过滤时,应根据具体的需求来选择使用在WHERE条件中还是SELECT语句中,以及如何与其他条件进行组合。




免责申明:


本文系转载,版权归原作者所有,如若侵权请联系我们进行删除!

《数据治理行业实践白皮书》下载地址:https://fs80.cn/4w2atu

《数栈V6.0产品白皮书》下载地址:
https://fs80.cn/cw0iw1

想了解或咨询更多有关袋鼠云大数据产品、行业解决方案、客户案例的朋友,浏览袋鼠云官网:
https://www.dtstack.com/?src=bbs

同时,欢迎对大数据开源项目有兴趣的同学加入「袋鼠云开源框架钉钉技术群」,交流最新开源技术信息,群号码:30537511,项目地址:
https://github.com/DTStack

0条评论
社区公告
  • 大数据领域最专业的产品&技术交流社区,专注于探讨与分享大数据领域有趣又火热的信息,专业又专注的数据人园地

最新活动更多
微信扫码获取数字化转型资料
钉钉扫码加入技术交流群