iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Oracle中行列转换及pivot子句怎么用
  • 268
分享到

Oracle中行列转换及pivot子句怎么用

2024-04-02 19:04:59 268人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关oracle中行列转换及pivot子句怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、11g以前的行列转换方法创建测试表:create

这篇文章将为大家详细讲解有关oracle中行列转换及pivot子句怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、11g以前的行列转换方法

创建测试表:

create table emp_phone(name varchar2(50), type char, phone varchar2(50));

insert into emp_phone values('张三', '1', '1234-5678');
insert into emp_phone values('张三', '2', '3219-6066');
insert into emp_phone values('张三', '3', '5365-9583');
insert into emp_phone values('李四', '1', '6837-2745');
insert into emp_phone values('李四', '3', '2649-5820');
insert into emp_phone values('王五', '1', '5838-9002');
insert into emp_phone values('王五', '2', '2749-5580');
insert into emp_phone values('陈六', '2', '9876-3453');
commit;

select * from emp_phone;

NAME                 T PHONE
-------------------- - --------------------
张三                 1 1234-5678
张三                 2 3219-6066
张三                 3 5365-9583
李四                 1 6837-2745
李四                 3 2649-5820
王五                 1 5838-9002
王五                 2 2749-5580
陈六                 2 9876-3453

列转行:

select name, max(decode(type, '1', phone)) home, max(decode(type, '2', phone)) office, max(decode(type, '3', phone)) mobile from emp_phone group by name;

NAME                 HOME                 OFFICE               MOBILE
-------------------- -------------------- -------------------- --------------------
陈六                                      9876-3453
王五                 5838-9002            2749-5580
李四                 6837-2745                                 2649-5820
张三                 1234-5678            3219-6066            5365-9583

行转回列:

create table emp_phone1 as
(select name, max(decode(type, '1', phone)) home, max(decode(type, '2', phone)) office, max(decode(type, '3', phone)) mobile from emp_phone group by name);
select * from emp_phone1;

NAME                 HOME                 OFFICE               MOBILE
-------------------- -------------------- -------------------- --------------------
陈六                                      9876-3453
王五                 5838-9002            2749-5580
李四                 6837-2745                                 2649-5820
张三                 1234-5678            3219-6066            5365-9583

select name, decode(lvl, 1, home, 2, office, 3, mobile) phone
  from emp_phone1, (select level lvl from dual connect by level <= 3)
 where decode(lvl, 1, home, 2, office, 3, mobile) is not null
 order by name;

NAME                 PHONE
-------------------- --------------------
陈六                 9876-3453
李四                 6837-2745
李四                 2649-5820
王五                 2749-5580
王五                 5838-9002
张三                 1234-5678
张三                 5365-9583
张三                 3219-6066

二、11g自带的行列转换

使用pivot和unpivot使得行列转换变的很简单。

列转行:
select * from emp_phone pivot(max(phone) for type in (1 as home, 2 as office, 3 as mobile));

NAME                 HOME                 OFFICE               MOBILE
-------------------- -------------------- -------------------- --------------------
陈六                                      9876-3453
王五                 5838-9002            2749-5580
李四                 6837-2745                                 2649-5820
张三                 1234-5678            3219-6066            5365-9583

行转列:
select * from emp_phone1 unpivot(phone for type in (home as 1, office as 2, mobile as 3));

NAME                       TYPE PHONE
-------------------- ---------- --------------------
陈六                          2 9876-3453
王五                          1 5838-9002
王五                          2 2749-5580
李四                          1 6837-2745
李四                          3 2649-5820
张三                          1 1234-5678
张三                          2 3219-6066
张三                          3 5365-9583

再举一个Oracle示例方案scott中的例子
select * from emp;

     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO
---------- ---------- --------- ---------- ------------------- ---------- ---------- ----------
      7369 SMITH      CLERK           7902 1980-12-17 00:00:00        800                    20
      7499 ALLEN      SALESMAN        7698 1981-02-20 00:00:00       1600        300         30
      7521 WARD       SALESMAN        7698 1981-02-22 00:00:00       1250        500         30
      7566 JONES      MANAGER         7839 1981-04-02 00:00:00       2975                    20
      7654 MARTIN     SALESMAN        7698 1981-09-28 00:00:00       1250       1400         30
      7698 BLAKE      MANAGER         7839 1981-05-01 00:00:00       2850                    30
      7782 CLARK      MANAGER         7839 1981-06-09 00:00:00       2450                    10
      7788 SCOTT      ANALYST         7566 1987-04-19 00:00:00       3000                    20
      7839 KING       PRESIDENT            1981-11-17 00:00:00       5000                    10
      7844 TURNER     SALESMAN        7698 1981-09-08 00:00:00       1500          0         30
      7876 ADAMS      CLERK           7788 1987-05-23 00:00:00       1100                    20
      7900 JAMES      CLERK           7698 1981-12-03 00:00:00        950                    30
      7902 FORD       ANALYST         7566 1981-12-03 00:00:00       3000                    20
      7934 MILLER     CLERK           7782 1982-01-23 00:00:00       1300                    10

列出各部门的工资总和
select * from (select sal, deptno from emp) pivot(sum(sal) for deptno in (10 as dept_10, 20 as dept_20, 30 as dept_30));

   DEPT_10    DEPT_20    DEPT_30
---------- ---------- ----------
      8750      10875       9400

这里deptno是有限的、可穷举的,如果是变化的、随机添加的,则可在in后面使用any或者子查询,此时查询的结果是XML格式串
select *
  from ((select sal, deptno from emp) pivot
        xml(sum(sal) for deptno in (any)));

如果是用子查询
select *
  from ((select sal, deptno from emp) pivot
        xml(sum(sal) for deptno in (select deptno from emp where deptno in (10, 20, 30))));

Oracle中行列转换及pivot子句怎么用

关于“Oracle中行列转换及pivot子句怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: Oracle中行列转换及pivot子句怎么用

本文链接: https://www.lsjlt.com/news/65199.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Oracle中行列转换及pivot子句怎么用
    这篇文章将为大家详细讲解有关Oracle中行列转换及pivot子句怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、11g以前的行列转换方法创建测试表:create...
    99+
    2024-04-02
  • 如何进行SQL中PIVOT行列转换
    这篇文章主要讲解了“如何进行SQL中PIVOT行列转换”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何进行SQL中PIVOT行列转换”吧!PIVOT通过将...
    99+
    2024-04-02
  • SQL Server中怎么使用Pivot和UnPivot实现行列转换
    这篇“SQL Server中怎么使用Pivot和UnPivot实现行列转换”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看...
    99+
    2023-06-28
  • 行转列之SQL SERVER PIVOT怎么用
    这篇文章主要介绍行转列之SQL SERVER PIVOT怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在数据库操作中,有些时候我们遇到需要实现“行转列”的需求,例如一下的表为某...
    99+
    2024-04-02
  • SQLServer使用PIVOT与unPIVOT实现行列转换
    一、sql行转列:PIVOT 1、基本语法: create table #table1 ( id int ,code varchar(10) , name v...
    99+
    2024-04-02
  • SQL Server如何使用PIVOT与unPIVOT实现行列转换
    这篇“SQL Server如何使用PIVOT与unPIVOT实现行列转换”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这...
    99+
    2023-06-30
  • 怎么使用SQL语句将行和列进行转换
    小编给大家分享一下怎么使用SQL语句将行和列进行转换,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!  如何使用SQL语句将行和列...
    99+
    2024-04-02
  • 如何进行Oracle中pivot与unpivot之间的相互转换
    如何进行Oracle中pivot与unpivot之间的相互转换,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 今天解答问题的总结 tabl...
    99+
    2024-04-02
  • SQLServer使用Pivot和UnPivot实现行列转换的问题小结
    对于行列转换的数据,通常也就是在做报表的时候用的比较多,之前也零零散散的看了一些,今天就来总结一下。 先创建一个用于演示的临时表: create table #temp ( ...
    99+
    2024-04-02
  • Oracle中where子句怎么用
    这篇文章给大家分享的是有关Oracle中where子句怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。查询emp表中20号部门的员工信息select&nb...
    99+
    2024-04-02
  • oracle行列转换的方法是什么
    在Oracle中,可以使用PIVOT和UNPIVOT命令来实现行列转换。 PIVOT:将行数据转换为列数据。例如,可以使用PIVO...
    99+
    2024-04-08
    oracle
  • oracle中怎么用unpivot函数实现列转行
    在Oracle中,可以使用UNPIVOT函数将多列转换为单列。以下是一个示例,假设有一个包含学生姓名、数学成绩和英语成绩的表格: C...
    99+
    2024-04-09
    oracle unpivot
  • mysql中怎么实现行列转换操作
    这篇文章将为大家详细讲解有关mysql中怎么实现行列转换操作,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。create table tx(id int pr...
    99+
    2024-04-02
  • mysql行转列的sql语句怎么写
    在MySQL中,可以使用以下方式将行转列: 使用CASE语句和聚合函数: SELECT id, MAX(CASE...
    99+
    2024-04-09
    mysql
  • 怎么在SQL中实现行转列和列转行
    怎么在SQL中实现行转列和列转行?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。行列转换就是如下图所示两种展示形式的互相转换行转列假如我们有...
    99+
    2024-04-02
  • oracle多行转多列怎么实现
    在Oracle中,可以使用PIVOT函数将多行数据转换为多列数据。以下是一个示例: 假设有一个名为sales的表,包含以下数据: ...
    99+
    2024-04-22
    oracle
  • oracle多行转一行多列怎么实现
    在 Oracle 中将多行数据转换为一行多列可以使用 LISTAGG 函数或者 PIVOT 操作。 使用 LISTAGG 函数: ...
    99+
    2024-04-17
    oracle
  • oracle中怎么用cast转换日期
    在Oracle中,可以使用CAST函数来转换日期数据类型。具体的语法如下: SELECT CAST(date_column ...
    99+
    2024-04-09
    oracle
  • SQL Server中怎么将行数据转换为列数据
    今天就跟大家聊聊有关SQL Server中怎么将行数据转换为列数据,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。准备工作创建表use [t...
    99+
    2024-04-02
  • SQLite中的SELECT子句怎么用
    这篇文章给大家分享的是有关SQLite中的SELECT子句怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。SQLite中的SELECT子句目前为止,最常见的SELEC...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作