首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SQL CASE 表达式

这个特性可以解决很多实际问题,比如将一些复杂聚合判断条件的结果用 SQL 结构输出,那么很可能是下面这种写法: SELECT CASE WHEN 聚合函数(字段) 符合什么条件 THEN xxx ......'no' END AS abc FROM test 原因是,只要 SQL 中存在聚合表达式,那么整条 SQL 就都是聚合的,所以返回的结果只有一条,而我们期望查询结果不聚合,只是判断条件用到了聚合结果...这个场景在 BI 工具里等价于,创建一个 CASE 表达式字段,可以拖入筛选条件生效。...可以写在 SQL 查询的几乎任何地方,只要是可以写字段的地方,基本上就可以替换为 CASE 表达式。...除了 SELECT 外,CASE 表达式还广泛应用在 INSERT 与 UPDATE,其中 UPDATE 的妙用是不用将 SQL 拆分为多条,所以不用担心数据变更后对判断条件的二次影响。

81730
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    神奇的 SQL 之 CASE表达式,妙用多多 !

    CASE表达式和 “2+1” 或者 “120/3” 这样的表达式一样,是一种进行运算的功能,正如CASE(情况)这个词的含义一样,用于区分情况,在有条件分歧的时候使用它。...然而,CASE表达式也许是 SQL-92 标准里加入的最有用的特性,如果能用好它,那么 SQL 能解决的问题就会更广泛,写法也会更加漂亮,而且,因为 CASE表达式 是不依赖于具体数据库的技术,所以可以提高...简单CASE表达式正如其名,写法简单,但能实现的功能比较有限。简单CASE表达式能写的条件,搜索CASE表达式也能写,所以基本上采用搜索CASE表达式的写法。...这是因为执行 条件1的SQL后,张三的薪资又满足条件2了,所以又更新了一遍,导致他的薪资变多了,有人可能会说,把条件1和条件2的SQL换下顺序不就好了吗,我们来试试 -- 条件2 UPDATE t_user_salaries...总结   1、CASE表达式 是支撑 SQL 声明式编程的根基之一,也是灵活运用 SQL 时不可或缺的基础技能。

    78130

    CASE语句与CASE表达式

    如省略且when条件中未找到任何匹配项,则收到case_not_found异常。...语句与搜索式case语句的异同 --相同点:两者都用于根据不同的条件,来执行与之对应的语句或完成特定的任务,甚至某些情况下可以互换替换。...: line 5, column 4: PL/SQL: Statement ignored 四、case表达式 --Case表达式与Case语句,如何理解呢?...分析如下: --Case表达式,那么when 之后接的一定是表达式或一个特定值。 --Case语句,那么when之后接的特定一个语句,或函数,或计算表达式。既然是语句则一定带有分号。...五、case嵌套 --case的嵌套就是case语句和表达式中嵌套case语句与表达式,理解了case的用法,case嵌套并不难。

    1.3K20

    算法工程师-SQL进阶:强大的Case表达式

    其实很大一部分时间还是:写SQL、分析数据、挖特征。 那你说,SQL能力重要不? 本节先介绍一下SQL中高频使用的case表达式,请认真感受它的灵活与强大! ?...一、case表达式是什么 case 表达式是 SQL 里非常重要而且使用起来非常便利的技术,我们常用它来描述条件分支。...这个例子的技巧是:分组后将count(*)等聚合函数作为分支判断条件,和having筛选group有相似的作用,但是比having功能更强大的是,case可以多层嵌套使用,在小组内部还可以使用case表达式进行分支过滤和重构...case表达式在SQL中是很常用的,它可以通过设置多组条件映射出不同的值; 时刻记得case表达式的结果是一个值,因此,它在sql中的位置相当灵活,不要忘了用end去结束一个case; case表达式用在...当case表达式用在having子句中,可以对小组设置灵活的过滤逻辑; 当需要自定义排序顺序时,可以在order by中通过使用case表达式来实现; case表达式还可以应用在update中,根据不同的分支条件采取不同的更新策略

    2.3K20

    java case when用法_sql case when 嵌套

    前几天在客户环境遇到一个Spark “CASE WHEN”语句的性能优化问题。 客户那边通过一个“时间范围筛选”控件来动态修改图表的数据。...CASE WHEN语句有些类似于编程语言中的Switch语句,当这里的 WHEN从句只有一个的时候,可以简化为IF语句(或者 IF-ELSE 语句)。...于是想:对于Spark(客户用的是2.4.x版本), Spark会不会把这种只有一个WHEN分支的 CASE WHEN 语句优化为IF语句呢?...于是试了一下性能,发现如果修改上面的SQL为: IF(`bizdate` BETWEEN ‘2020-09-06’ AND ‘2020-09-13’, `sales_amount`, 0 ) 那么执行速度将减少为原来的一半...首先、这个应该是一个比较简单的优化,比如我是否可以通过增加一个Spark的优化器规则,来自动把一个分支的CASE WHEN转为IF,看着好像不难。

    3.1K30

    【DB笔试面试455】条件表达式CASE和DECODE的区别是什么?

    题目部分 条件表达式CASE和DECODE的区别是什么? 答案部分 在SQL语句中使用IF-THEN-ELSE逻辑,可以使用两种方法:CASE表达式、DECODE函数。...1、CASE表达式 SQL中CASE的使用方法具有两种格式:简单CASE函数和CASE搜索函数。...AS "类别" CASE表达式可以在SQL中实现IF-THEN-ELSE型的逻辑,而不必使用PL/SQL。...CASE的工作方式与DECODE类似,但推荐使用CASE,因为它与ANSI兼容。 对于CASE表达式,需要注意以下几点内容: (1)以CASE开头,以END结尾。...(2)分支中WHEN后跟条件,THEN为显示结果。 (3)ELSE为除此之外的默认情况,类似于高级语言程序中SWITCH CASE的DEFAULT,可以不加。

    1.2K20

    巧用switch-case消除条件判断

    在之前的文章中,我们有提交消除if-else代码的方法:结合HashMap与Java 8的Function和Optional消除ifelse判断巧用枚举消除逻辑判断现在分享最原始、也是最简单的switch-case...你会觉得震惊不已:public String handleQuestionV4(String type, String detail) { return switch (type) { case..."A" -> handleQuestionA(detail); case "B" -> handleQuestionB(detail); case "C" -> handleQuestionC...这个和lambda表达式的写法很像。它的原始版本是这样的:这里也不得不赞叹下IDEA的强大,直接把代码优化到如此优雅。...OK,让我们现在回忆下目前知道的消除条件判断的方式:借助HashMap借助enum枚举类借助switch-case下一篇将会分享结合spring框架IOC能力实现条件判断的消除。

    6310
    领券