oracle怎么转换为列-Oracle

admin2年前 (2024-06-05)基础运维知识309
点击下载TXT

如何将 Oracle 数据转换成列

Oracle 数据库提供了一个名为 PIVOT 的函数,它可以将行数据转换为列数据。PIVOT 函数的语法如下:

PIVOT (
    agg_expr
    FOR col_name
    IN (value1, value2, ..., valueN)
    [PARTITION BY partition_col_name1, ..., partition_col_nameN]
)
登录后复制

示例:

将以下表中的行数据转换为列数据:

ID Name Sport
1 John Basketball
2 Mary Soccer
3 Bob Basketball
4 Jane Soccer
5 Tom Baseball

使用 PIVOT 函数将其转换为列数据:

SELECT ID,
       MAX(CASE WHEN Sport = 'Basketball' THEN Name END) AS Basketball,
       MAX(CASE WHEN Sport = 'Soccer' THEN Name END) AS Soccer,
       MAX(CASE WHEN Sport = 'Baseball' THEN Name END) AS Baseball
FROM (
    SELECT ID, Name, Sport
    FROM table_name
)
PIVOT (
    Name
    FOR Sport
    IN ('Basketball', 'Soccer', 'Baseball')
)
GROUP BY ID;
登录后复制

输出:

ID Basketball Soccer Baseball
1 John NULL NULL
2 NULL Mary NULL
3 Bob NULL NULL
4 NULL Jane NULL
5 NULL NULL Tom

相关文章

oracle解释计划怎么看-Oracle

如何解读 Oracle 解释计划 Oracle 解释计划是数据库提供的关于 SQL 语句执行计划的信息。它提供了对语句如何执行以及为什么以这种方式执行的深入见解。了解如何解读解释计划对于优化查询性能...

oracle日期比较怎么写-Oracle

Oracle 中比较日期的方法 在 Oracle 中比较日期有两种主要方法: 1. 直接比较 最直接的方法是使用比较运算符,例如: SELECT * FROM table_name WHERE da...

oracle序列怎么取出来-Oracle

如何获取 Oracle 序列值 获取 Oracle 序列值的方法有两种: 1. 使用 NEXTVAL 函数 NEXTVAL 函数返回序列的下一个值,并将序列的值加 1。语法如下: SELECT NE...

oracle索引怎么用-Oracle

Oracle 索引的用途 索引在 Oracle 数据库中扮演着至关重要的角色,它有助于加快对数据的访问速度,进而提升查询性能。 索引的工作原理 索引是数据库中的一种特殊数据结构,它基于表的列值创建。...

oracle怎么打开数据库-Oracle

如何打开 Oracle 数据库 打开数据库的步骤: 打开 Oracle 数据库客户端。 连接到数据库服务器。 使用 SQLPLUS 命令打开数据库。 具体步骤: 1. 打开 Oracle 数据库...

oracle decode怎么排序的-Oracle

Oracle DECODE 排序规则 Oracle DECODE 函数用于基于条件将表达式转换为指定值,在对 DECODE 函数的结果进行排序时,Oracle 遵循以下规则: 1. CASE WHE...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。