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

SQL中CASE表达式的妙用

case 表达式作为标准SQL的用法,真的是很强大。 case 表达式分为搜索表达式和简单表达式,由于搜索表达式包含了简单表达式的所有用法,此处仅介绍搜索表达式的用法。...搜索 case 表达式的语法如下: CASE WHEN 表达式> THEN 表达式> WHEN 表达式> THEN 表达式> WHEN 表达式> THEN...取代小表关联 之前工作中遇到一个需求,需要将表中的某列进行转换,以得到新的列,当时采用的创建小表,然后再进行内连接的方法。...最近学习 case 表达式的用法,发现正好可以用来完成此工作。...case when 表达式 + 聚合函数可以实现行转列 -- case when 实现数字列 score 行转列 select name, sum(case when subject = '语文

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

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

    CASE表达式 之概念   相信大家都用过CASE表达式,尤其是做一些统计功能的时候,用的特别多,可真要说什么是 CASE表达式,我估计还真没几个人能清楚的表述出来。...基本格式如下 -- 简单 CASE表达式 CASE 列(或表达式) WHEN THEN 表达式> WHEN THEN 表达式> .........简单CASE表达式正如其名,写法简单,但能实现的功能比较有限。简单CASE表达式能写的条件,搜索CASE表达式也能写,所以基本上采用搜索CASE表达式的写法。...)或 DECODE(Oracle),但这两者都不是标准的 SQL,更推荐大家用 CASE表达式,移植性更高     假设我们有如下表,以及如下数据 CREATE TABLE t_customer_credit...有如下两种方法 -- 1、CASE表达式 集合 GROUP BY SELECT province_name, SUM(CASE WHEN sex = 1 THEN population ELSE

    78130

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

    本节先介绍一下SQL中高频使用的case表达式,请认真感受它的灵活与强大! ? 一、case表达式是什么 case 表达式是 SQL 里非常重要而且使用起来非常便利的技术,我们常用它来描述条件分支。...你也可以同时写多个case表达式,但是每个case表达式的结果都将作为一列返回到最终的查询结果中。 2、自定义分组规则 case表达式可以用在group子句中,作用是:自定义分组规则。...,在select语句中使用了两个case表达式,第一个case表达式是将所有sex!...THEN 1 ELSE 0 END) >= count(*)/2) TEMP; 解析:一般说来,当要根据某一列的大小关系求该列的子集时,要用到非等值自连接(后面章节会讲到)。...先说(1),使用一个case表达式就可以得到两个数的最大值,然后在嵌套一个case表达式就可以得到三个数的最大值。

    2.3K20

    包含列的索引:SQL Server索引进阶 Level 5

    包括列 在非聚集索引中但不属于索引键的列称为包含列。 这些列不是键的一部分,因此不影响索引中条目的顺序。 而且,正如我们将会看到的那样,它们比键列造成的开销更少。...创建非聚集索引时,我们指定了与键列分开的包含列; 如清单5.1所示。...确定索引列是否是索引键的一部分,或只是包含的列,不是您将要做的最重要的索引决定。也就是说,频繁出现在SELECT列表中但不在查询的WHERE子句中的列最好放在索引的包含列部分。...为了说明在索引中包含列的潜在好处,我们将查看两个针对SalesOrderDetailtable的查询,每个查询我们将执行三次,如下所示: 运行1:没有非聚集索引 运行2:使用不包含列的非聚簇索引(只有两个关键列...扫描索引而不是表格有两个好处: 索引小于表,需要更少的读取。 行已经分组,需要较少的非阅读活动。 结论 包含的列使非聚集索引能够覆盖各种查询的索引,从而提高这些查询的性能; 有时相当戏剧性。

    2.4K20

    select count(*)、count(1)、count(主键列)和count(包含空值的列)有何区别?

    下班路上看见网上有人问一个问题: oracle 10g以后count(*)和count(非空列)性能方面有什么区别?...首先,准备测试数据,11g库表bisal的id1列是主键(确保id1列为非空),id2列包含空值, ?...前三个均为表数据总量,第四个SQL结果是99999,仅包含非空记录数据量,说明若使用count(允许空值的列),则统计的是非空记录的总数,空值记录不会统计,这可能和业务上的用意不同。...其实这无论id2是否包含空值,使用count(id2)均会使用全表扫描,因此即使语义上使用count(id2)和前三个SQL一致,这种执行计划的效率也是最低的,这张测试表的字段设置和数据量不很夸张,因此不很明显...总结: 11g下,通过实验结论,说明了count()、count(1)和count(主键索引字段)其实都是执行的count(),而且会选择索引的FFS扫描方式,count(包含空值的列)这种方式一方面会使用全表扫描

    3.4K30

    关于SQL里面两个case when then的应用案例

    70'); INSERT INTO `exam` VALUES ('李四', '数学', '80'); INSERT INTO `exam` VALUES ('李四', '英语', '90'); 查询的结果如下...张三 0 98 0 张三 0 0 65 李四 70 0 0 李四 0 80 0 李四 0 0 90 不是想要的效果,我们需要加个分组,然后取最大的那个科目分数即可...: select name as '姓名', max(case when subject='语文' then score else 0 end) as '语文', max(case when subject...exam group by name 结果: 姓名 语文 数学 英语 张三 80 98 65 李四 70 80 90 (例子二)使用case when then生成虚拟列统计,我们现在的科目数据里面每个人没有分文科和理科类别...then '文科' else '其他' end 结果: 姓名 科别 总分 张三 文科 145 张三 理科 98 李四 文科 160 李四 理科 80 符合我们的预期结果

    1.4K20

    两种主要列存储方式的区别

    我认为,称呼这两个系统的列存储导致了大量的混乱和错误的预期。这篇博客文章试图澄清一些这种混乱,突出这些集合系统之间的高级差异。 最后,我将提出一些可能的方法来重命名这些组,以避免将来混淆。...对于本博客文章,我将引用以下两个组作为组A和组B: •组A:Bigtable,HBase,Hypertable和Cassandra。...列的独立性:组A将数据实体或“行”的部分存储在单独的列族中,并且能够单独访问这些列族。...我们可以找出它来自哪个列,因为来自同一列的所有值都是连续存储的。我们可以通过计算在同一列中有多少值来计算它来自哪一行。 id列中的第四个值匹配到与姓氏列中的第四个值相同的行以及电话列中的第四个值等。...因此,即使调用它们两个列存储有一些优点(它使得看起来像“列存储运动”是一个真正的热门),我们需要作出更大的努力,以避免将来这两组混淆。

    1.5K10

    Excel中两列(表)数据对比的常用方法

    Excel中两列数据的差异对比,方法非常多,比如简单的直接用等式处理,到使用Excel2016的新功能Power Query(Excel2010或Excel2013可到微软官方下载相应的插件...一、简单的直接等式对比 简单的直接等式对比进适用于数据排列位置顺序完全一致的情况,如下图所示: 二、使用Vlookup函数进行数据的匹配对比 通过vlookup函数法可以实现从一个列数据读取另一列数据...vlookup函数除了适用于两列对比,还可以用于表间的数据对比,如下图所示: 三、使用数据透视进行数据对比 对于大规模的数据对比来说,数据透视法非常好用,具体使用方法也很简单,即将2列数据合并后...比如,有两个表的数据要天天做对比,找到差异的地方,原来用Excel做虽然也不复杂,但要频繁对比,就很麻烦了,因此,可以考虑使用Power Query来实现直接刷新的自动对比。...1、将需要对比的2个表的数据加载到Power Query 2、以完全外部的方式合并查询 3、展开合并的数据 4、添加差异比对列 5、按需要筛选去掉无差异部分 6、按需要调整相应的列就可以将差异结果返回

    16.3K20

    Innodb主键包含全部列的情况下,如何组织物理页

    很简单,和有不是主键的列的格式一样。 实验:在 Mysql 8 中 创建一张主键包含全部列的表 ? 插入 10000 条数据。 ?...因为是字符串做为主键(为了好辨别),所以大小是按照字典序来的 使用工具查看叶子节点结构,下面是部分截图,剩下的部分都是 一样的 level 为0的数据页。 着重看索引叶。...也就是 level 为1的B+树叶 ? 查看索引叶(偏移量为4的数据页): ?...发现偏移量为5的数据页,含有的记录的主键最小值是 sss...0bbbbb...0 偏移量为6的数据页,含有的记录的主键最小值是sss...195bbbb...0 sss...N 这里的N是从0~10000...而112 是 1119 字典序的下一个,所以逻辑正确。虽然第11页和第5页不是物理上连续,但是两者逻辑上通过偏移量指针 5 指向 11 ,建立了逻辑联系。 并且块之间的主键大小应该是 递增的。

    57720

    会计学包含的两种程序设计思想

    下班路上坐地铁的时候看了一本会计学的书,目前看了50多页。过程中,发现会计学和程序设计在思想上有惊人的相似之处。今天举两个例子做说明。...账簿介绍 这个思想的产生要追溯到石器时代。石器时代就有结绳记事。那些绳子就是原始人的账簿。登记方法就是增加的时候在上面接个大疙瘩,减少的时候解开大疙瘩。...估计那个时候中国人还不知道“+”和“-”这两个符号,只好把增加和减少分开写,中国人的习惯是上面写增加、下面写减少(天收地付)。 CR设计应用 在现在的工程架构中,能运用软件的就尽量不用硬件。...复式记账法是指对发生的每一项经济业务,都要以相等的金额,在相互联系的两个或两个以上的账户中进行记录的记账方法。...这种方法的优点是对于发生的每一项经济业务,都要在两个或两个以上的账户中相互联系地进行分类记录。这样,通过账户记录不仅可以全面、清晰地反映经济业务的来龙去脉,还能全面、系统地反映经济活动的过程和结果。

    40230
    领券