首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

SQL教程:转列

SQL刷题专栏 SQL145题系列 CASE函数的类型 CASE具有两种格式,简单CASE函数和CASE搜索函数。这两种方式,大部分情况下可以实现相同的功能。...比如说,下面这段SQL,你永远无法得到“第二类”这个结果 CASE WHEN Type IN ('a','b') THEN '第一类' WHEN Type IN ('a') THEN...'第二类' ELSE '其他类' END 转列 CASE用的比较广泛的功能就是转列,就是将记录里的数据按条件转换成具体的列。...THEN 分数 ELSE 0 END) 数学, MAX(CASE 课程 WHEN N'物理' THEN 分数 ELSE 0 END) 物理 FROM Score GROUP BY 姓名 执行结果如下: 转列新方法...PIVOT( MAX(分数) FOR 课程 IN (语文,数学,物理)) A 其中FOR后面的是我们即将进行行转列的列部分 IN里面的是我们转列之后的列 MAX是聚合IN里面的内容,也可以是其他聚合函数

6510

SQL Server 动态转列(参数化表名、分组列、转列字段、字段值)

、分组字段、转列字段、值这四个转列固定需要的值变成真正意义的参数化,大家只需要根据自己的环境,设置参数值,马上就能看到效果了(可以直接跳转至:“参数化动态PIVOT转列”查看具体的脚本代码)。...(图3:样本数据) (三) 接着以动态的方式实现行转列,这是使用拼接SQL的方式实现的,所以它适用于SQL Server 2000以上的数据库版本,执行脚本返回的结果如图2所示; 1 --2:动态拼接转列...(图4) (五) 把上面静态的SQL基础上进行修改,这样就不用理会记录里面存储了什么,需要转成什么列名的问题了,脚本如下,效果如图4所示: 1 --4:动态PIVOT转列 2 DECLARE @sql_str...、分组列、转列字段、字段值这几个参数,逻辑如图5所示, 1 --5:参数化动态PIVOT转列 2 -- =============================================...: 4 -- Create date: 5 -- Description: <参数化动态PIVOT转列,带条件查询的参数化动态PIVOT

4.2K30

table转列sql详解

table转列sql详解 tabele转列的资料,网上搜一下很多。大家照着网上copy就可以实现自己想要的功能。但是大家在实现功能后是否想过转列为什么要这样写?...5    math    93.0 6    chinese    67.0 7    math    83.0 8    chinese    77.0 8    math    84.0 3 转列后的结果...73.0 4    82.0    0.0 5    66.0    93.0 6    67.0    0.0 7    0.0    83.0 8    77.0    84.0 二 、分析 1 转列...可以根据subject的值去动态的组sql语句 看下面的一段代码 declare @sql varchar(2000) set @sql='' select @sql =@sql+ ',case subject...declare @sql varchar(2000) set @sql='select stuid' select @sql =@sql+ ',sum(case subject when '''+subject

70620

SQL 转列+窗口函数的实例

今天继续和大家分享 HackerRank 上的 SQL 编程挑战的解题思路,这一次的题目叫做“Occupations”,属于中等难度级别,答案提交的成功率在 90% 左右。...Christeen Priya Julia NULL Ketty NULL Maria 解决方案 一般遇到“将一列中的所有唯一值作为新的列名输出”这种需求,我们首先想到的就应该是转列...,我之前写过一篇介绍SQL 转列的通用实现的文章,感兴趣的朋友点进来看看。...做转列时分组的依据是什么呢?即依据哪个字段分组。答案是依据每个职位中姓名的排序序号作为分组条件,而每个职位里面姓名的出现的序号可通过窗口函数求得。...Jennifer Actor 3 Ketty Actor 4 Samantha Doctor 1 Aamina Doctor 2 Julia Doctor 3 Priya 最后,我们把窗口函数和转列结合起来

2K10

SQL中的转列和列转行

而在SQL面试中,一道出镜频率很高的题目就是转列和列转行的问题,可以说这也是一道经典的SQL题目,本文就这一问题做以介绍分享。 ? 给定如下模拟数据集,这也是SQL领域经典的学生成绩表问题。...scoreWide 考察的问题就是通过SQL语句实现在这两种形态间转换,其中长表转为宽表即行转列,宽表转为长表即列转行。...01 转列:sum+if 在行转列中,经典的解决方案是条件聚合,即sum+if组合。...按照这一思路,一句SQL实现行转列的写法如下: SELECT uid, sum(if(course='语文', score, NULL)) as `语文`, sum(if(course...NULL)) as `物理`, sum(if(course='化学', score, NULL)) as `化学` FROM scoreLong GROUP BY uid 查询结果当然是预期的转列后的结果

7K30
领券