首页
学习
活动
专区
圈层
工具
发布

Oracle行转列,pivot函数和unpivot函数

Oracle 测试数据 行转列 以下一般是行转列的正常需求: image.png 要完成该需求,可以用两种方法 一是:CASE WHEN+GROUP BY 二是PIVOT函数 我们用第二种 SELECT...* FROM TEST_PIVOT PIVOT(SUM(SCORE) FOR COURSE IN('英语','数学','语文'))B image.png 这些中文字段名比较刺眼,王五的 英语列和 数学列也为空不好看...FROM TEST_PIVOT PIVOT(SUM(SCORE) FOR COURSE IN('英语' AS ENGLISH ,'数学' AS MARTH,'语文' AS LANGUAGES)) image.png...为什么聚合函数用的是SUM原因是要看具体的逻辑,如果李四的语文补考了一次,不同的聚合函数代表不同的逻辑: image.png 列转行 image.png 要完成该需求,可以用两种方法 一是:UNION...ALL 二是UMPIVOT函数 我们用第二种 SELECT name,COURSE,SCORE FROM TEST_PIVOT1 T UNPIVOT(SCORE FOR COURSE IN(ENGLISH

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

    SUM函数在SQL中的值处理原则

    theme: smartblue 在SQL中,SUM函数是用于计算指定字段的总和的聚合函数。...函数作用字段所有匹配记录均为NULL的情况 如果SUM函数作用的字段在所有匹配的记录中均为NULL,那么SUM函数的结果也会是NULL。...SUM函数作用字段存在非NULL值的情况 如果SUM函数作用的字段在所有匹配的记录中存在任意一条数据不为NULL,那么SUM函数的结果将不会是NULL。...where id in (1,2); 查询SQL-存在非NULL的情况 select sum(amount) from balance; 在存在非NULL值的情况下, SUM函数会将所有非NULL值相加...适用范围: SUM函数主要用于对数值型数据的求和,不适用于非数值型数据。 后续内容文章持续更新中… 近期发布。

    2.1K10

    Power Pivot中DAX的时间函数

    (一) 和Excel相同用法函数 这里就不多做介绍。主要是介绍差异及DAX特有函数。 (二) 和Excel有差异函数 1....差异情况 差异原因 Excel函数 Dax函数 函数名称 DateDif DateDiff 计算方式 根据实际时间 只根据计算条件 2....填写1-12的月份数字 往前推或者往后延做成年份日期表 B) 返回 表——单列日期表 C) 注意事项 如果数据表中没有日期列则会出错 参数为正数则表示会计年份从1月往后算,负数则是从1月往前算。...D) 作用 自动生成会计日期列 E) 案例 自动生成时间日历表 CALENDARAUTO() 如果数据模型的日期范围是2018/5/1—2019/6/30,则生成的日期表范围为2018/1/1—2019.../12/31 生成会计年度为每年4月 CALENDARAUTO(3) 如果数据模型的日期范围为2018/1/1—2018/12/31,则生成的日期表范围为2017/4/1—2019/3/31。

    2.2K10

    Power Pivot信息函数中的判断

    信息判断函数 ? 比较显著的逻辑判断函数我们这里就省略了,例如IsBlank,IsText,IsError等。 我们先来看下其他不怎么常用的逻辑判断函数 (一) IsOnOrAfter A....请注意不同属性的判断依据。 D. 作用 针对每一行进行判断并返回逻辑值。 E. 案例 ? 需要筛选出找出日期为5/21日及之前的,同时等级为B级之前的内容。 表格的筛选我们使用Filter函数。...我们可以看到最终的结果是品牌为华为,等级为A和B的产品。而googl产品,因为日期不符合要求被排除在外了。 (二) CONTAINS 1....注意事项 查找的列和需要查找的值必须成对出现 查找的列必须是表里的列或者是关联表的列 如果是引用相关表的列,则相关表必须是多对1关系中处于1的表。 4....后面个判断公式引用给了多对1关系中的1表中的列。 (三) CONTAINSROW 1.

    1.7K10

    SQL中的行转列和列转行

    而在SQL面试中,一道出镜频率很高的题目就是行转列和列转行的问题,可以说这也是一道经典的SQL题目,本文就这一问题做以介绍分享。 ? 给定如下模拟数据集,这也是SQL领域经典的学生成绩表问题。...01 行转列:sum+if 在行转列中,经典的解决方案是条件聚合,即sum+if组合。...其基本的思路是这样的: 在长表的数据组织结构中,同一uid对应了多行,即每门课程一条记录,对应一组分数,而在宽表中需要将其变成同一uid下仅对应一行 在长表中,仅有一列记录了课程成绩,但在宽表中则每门课作为一列记录成绩...按照这一思路,一句SQL实现行转列的写法如下: SELECT uid, sum(if(course='语文', score, NULL)) as `语文`, sum(if(course...这样,无论使用任何聚合函数,都可以得到该uid下指定课程的成绩结果。这里是用了sum函数,其实用min、max效果也是一样的,因为待聚合的数值中就只有那一个值非空。

    9.7K30

    Power Pivot中3大汇总函数的配套组合函数

    返回 返回分组依据的小计汇总,不返回可被引用的具体值 C. 注意事项 仅在SUMMARIZE和ADDMISSINGITEMS函数中使用。 如果和RollUp用法一样,效果也类似同RollUp。...解释: 根据2个字段,姓名和学校进行的汇总,然后再对2个字段的小计进行汇总。...注意事项 只能用于SUMMARIZECOLUMNS函数中 D. 作用 判断是否为总计。 E. 案例 ?...返回 表——需要显示的列及汇总依据列及值生成的表。 C. 注意事项 如果和ROLLUPISSUBTOTAL和ISSUBTOTAL函数一起使用,参数要一致 D. 作用 重新添加包含空度量值的行 E....解释: 如果单纯通过SummarizeColumns函数进行分组的话,如果计算值为0的话,分组的内容会缺失,但是通过AddMissingItems函数可以进行恢复。

    1.6K20

    SQL 行转列+窗口函数的实例

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

    2.2K10

    从Excel角度理解Power Pivot中的行上下文

    Excel中的绝对引用和相对引用。 我们知道Excel中有绝对引用和相对引用。用$表示绝对引用。 例如 ? 这样的代表是相对引用。 ?...Sum([@列1])这个我们也相对可以好理解,求和列1当前行的值,也就是1,所以D2返回的应该是1,D3是2一次类推。 我们反过来再看C2和E2会返回什么结果呢?...知识点: ,代表的是多列, ;代表的是多行。 例:{1,2,3;4,5,6}代表的就是3列2行的矩阵表。 ? ?...实际里面的公司是Sum({1;2;3;4;5}),所以返回的是15。我们看下最终各个单元格返回的结果。 ? 3....Power Pivot中的引用 我们知道Power Pivot是以超级表为基础,所以在某些方面还是比较类似。 ? ? 这样我们就知道为什么有些时候上下文引用是整列,有些时候是引用当前行。

    1.3K20

    SQL Server中的DataLength和Len函数

    Len返回字符串的字符长度,这个好理解,一个汉字'狮'+4个字母'lion'=5个字符.每个汉字和字母都占一个字符长度....DataLength返回字符串的字节长度.对于字节长度,需要理解:一般编码模式下,汉字和英文字母所占字节是不一样的.一般来说,汉字占2个字节,英文字符占一个字节.而对于Unicode编码,汉字和英文字母都占...讲解一下varchar和nvarchar的区别,varchar是普通编码的字符串,nvarchar是Unicode编码的字符串,对应例子,就是对汉字'狮'来说,varchar格式的字符串长度为1,nvarchar...lion')) --返回字节长度,varchar格式字符'狮lion','狮'占2个字节, --'lion'中每个字母占用一个字节...datalength(N'狮lion') --返回字节长度,Unicode格式字符,汉字'狮'占2个字节, --'lion'中每个字母占用

    2K30

    详解Python的max、min和sum函数用法

    max()、min()、sum()这三个内置函数分别用于计算列表、元组或其他可迭代对象中所有元素最大值、最小值以及所有元素之和,sum()只支持数值型元素的序列或可迭代对象,max()和min()则要求序列或可迭代对象中的元素之间可比较大小...下面的代码首先使用列表推导式生成包含10个随机数的列表,然后分别计算该列表的最大值、最小值和所有元素之和。...) 函数max()和min()还支持default参数和key参数,其中default参数用来指定可迭代对象为空时默认返回的最大值或最小值,而key参数用来指定比较大小的依据或规则。...函数sum()还支持start参数,用来控制求和的初始值。...default=None)) #对空列表求最大值,返回空值None None >>> sum(range(1, 11)) #sum()函数的start参数默认为0 55 >>> sum(range(1

    3.4K40

    SQL 中的聚集函数?

    SQL 中的聚集函数? SQL 函数包含了算术函数,字符串函数,日期函数,转换函数。还有一函数,叫做聚集函数。SQL 聚集函数是对一组数据进行汇总的函数,输入是一组数据的集合,输出是单个值。...有哪些聚集函数 SQL 中的聚集函数,有最大值,最小值,平均值。 ? image Count 使用 例子:查询heros 中hp_max 大于6000 的英雄。...对数据行中不同的取值进行聚集,过滤掉重复,可以写成如下: SELECT COUNT(DISTINCT hp_max) FROM heros 运⾏结果为61。...COUNT,AVG、MAX、MIN和SUM函数使用 SELECT COUNT(*), AVG(hp_max), MAX(mp_max), MIN(attack_max), SUM(defense_max...image HAVING 与 WHERE 的区别是什么? HAVING 和 WHERE 一样可以进行锅炉,只是 WHERE 作用于数据行, HAVING 作用于分组。

    1.5K10

    MySQL中的行转列和列转行操作,附SQL实战

    本文将详细介绍MySQL中的行转列和列转行操作,并提供相应的SQL语句进行操作。行转列行转列操作指的是将表格中一行数据转换为多列数据的操作。在MySQL中,可以通过以下两种方式进行行转列操作。1....PIVOT函数PIVOT函数是MySQL8.0版本中新增的函数,用于实现行转列操作。...SUM(order_amount)部分是对原始数据中相同年份的订单金额进行求和。2. 自定义SQL语句除了使用PIVOT函数外,还可以使用自定义的SQL语句实现行转列操作。...这种方法需要使用到MySQL的聚合函数和CASE语句。...结论MySQL中的行转列和列转行操作都具有广泛的应用场景,能够满足各种分析和报表需求。在实际应用中,可以根据具体的需求选择相应的MySQL函数或编写自定义SQL语句进行操作。

    22K20
    领券
    首页
    学习
    活动
    专区
    圈层
    工具
    MCP广场