深圳北站网站建设南京江北新区
web/
2025/10/8 2:38:08/
文章来源:
深圳北站网站建设,南京江北新区,顶尖的赣州网站建设,dw不会写代码能建立网站吗ORACLE行转列、列转行实现方式及案例 行转列案例方式1.PIVOT方式2.MAX和DECODE方式3.CASE WHEN和GROUP BY 列转行案例方式1.UNPIVOT方式2.UNION ALL 行转列
案例
假设我们有一个名为sales的表#xff0c;其中包含了产品销售数据。表中有三列#xff1a;product#xff08;… ORACLE行转列、列转行实现方式及案例 行转列案例方式1.PIVOT方式2.MAX和DECODE方式3.CASE WHEN和GROUP BY 列转行案例方式1.UNPIVOT方式2.UNION ALL 行转列
案例
假设我们有一个名为sales的表其中包含了产品销售数据。表中有三列product产品名称、year年份和amount销售额。表中的数据如下 将这个表中的数据进行行转列使得每一行表示一个产品每一列表示一年的销售额。 使得得到以下结果
方式1.PIVOT
PIVOT是Oracle 11g之后引入的一种用于行列转换的函数。它可以将查询结果中的行数据转换为列数据从而实现行列转换。PIVOT函数的基本语法如下
SELECT ...
FROM ...
PIVOT (aggregate_function(column_to_aggregate)FOR column_to_pivotIN (list_of_values))其中aggregate_function是一个聚合函数如SUM、MAX、MIN等column_to_aggregate是要进行聚合的列column_to_pivot是要进行行列转换的列list_of_values是要转换为列的值的列表。
实现案例所示效果可以通过如下方式
SELECT *
FROM sales
PIVOT (SUM(amount) FOR year IN (2018, 2019, 2020));方式2.MAX和DECODE
DECODE 可以根据条件返回不同的值。DECODE 函数的基本语法如下
DECODE(expression, search1, result1,search2, result2, ..., default)
其中expression 是要进行比较的表达式search1、search2 等是要进行比较的值result1、result2 等是当表达式与对应的搜索值相等时返回的结果default 是当表达式与所有搜索值都不相等时返回的默认值。
若要实现案例的效果可以通过以下方式
SELECT product,MAX(DECODE(year, 2018, amount)) AS 2018,MAX(DECODE(year, 2019, amount)) AS 2019,MAX(DECODE(year, 2020, amount)) AS 2020
FROM sales
GROUP BY product;
注意这里取的是每年数据的最大值每年每产品指只会一条而方式3是取总和
方式3.CASE WHEN和GROUP BY
SELECT product,SUM(CASE WHEN year 2018 THEN amount END) AS 2018,SUM(CASE WHEN year 2019 THEN amount END) AS 2019,SUM(CASE WHEN year 2020 THEN amount END) AS 2020
FROM sales
GROUP BY product;
注意这里取的是每年数据的总和每年每产品的总和而方式2是取最大的一条
列转行
案例
与行转列的案例相反假设我们有一个名为sales的表其中包含了产品销售数据。表中有四列product产品名称、20182018年销售额、20192019年销售额和20202020年销售额。表中的数据如下 现在我们想要将这个表中的数据进行列转行使得每一行表示一个产品在某一年的销售额。 实现效果如下
方式1.UNPIVOT
UNPIVOT是Oracle中用于实现列转行的函数基本语法如下
SELECT ...
FROM ...
UNPIVOT (column_to_unpivotFOR new_column_nameIN (list_of_columns))
其中column_to_unpivot是要进行列转行的列new_column_name是新生成的列的名称list_of_columns是要转换为行的列的列表。
实现案例中的结果可以用如下方式
SELECT *
FROM sales
UNPIVOT (amount FOR year IN (2018, 2019, 2020));
方式2.UNION ALL
SELECT product, 2018 AS year, 2018 AS amount FROM sales
UNION ALL
SELECT product, 2019 AS year, 2019 AS amount FROM sales
UNION ALL
SELECT product, 2020 AS year, 2020 AS amount FROM sales;
注意单引号表示的是固定字符2018即字段名2018双引号表示字段2018下的值
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/88832.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!