`

ORACLE 10g 的行列互转函数

阅读更多
行列互转下面这个函数最简单,虽然是多行转一列,但正是我要的结果。感觉有点象字符类型的sum函数,哈哈。(直接从别人的贴在粘贴过来的哈。);sys_context的用法学习了。

SQL> create table test(c1 varchar2(10),c2 number);

Table created

SQL> insert into test values('A',80);

1 row inserted

SQL> insert into test values('B',70);

1 row inserted

SQL> insert into test values('C',80);

1 row inserted

SQL> insert into test values('D',60);\

1 row inserted

SQL> insert into test values('E',70);

1 row inserted

SQL> commit;

Commit complete

SQL> select * from test;

C1               C2
---------- ----------
A                 80
B                 70
C                 80
D                 60
E                 70

SQL> select WMSYS.WM_CONCAT(c1),c2 from test group by c2;

WMSYS.WM_CONCAT(C1)                                                  C2
-------------------------------------------------------------------------------- ----------
D                                                                                       60
B,E                                                                                    70
A,C                                                                                    80

SQL>
分享到:
评论

相关推荐

    oracle行列转换总结

    集合类型如`VARRAY`或`NATIVE ARRAY`也可以用于行列转换,特别是在Oracle 8i、9i和10g版本中。这种方法涉及创建集合类型的对象,然后将列数据插入到这些对象中。例如: 首先定义集合类型: ```sql CREATE TYPE cv_...

    oracle数据行列转换

    本篇文章将详细讲解Oracle 10g中的行列转换技术,包括如何实现行转列和列转行。 首先,我们要了解为什么要进行行列转换。在实际业务场景中,有时我们需要将多行数据合并到一列,或者将一列数据分散到多行,以适应...

    Oracle 行列转换总结

    适用于Oracle 8i、9i、10g及以上版本。 - **步骤与示例**: - 首先创建一个表`t_col_row`,包含三列`c1`、`c2`、`c3`。 - 插入几条记录,其中部分记录包含空值。 - 使用`UNION ALL`将每一列的数据转换为一行,...

    Oracle的列转行问题

    当然,Oracle数据库从11g版本开始提供了更高级的`PIVOT`和`UNPIVOT`操作,它们是专为行列转换设计的内置功能,使用起来更为简洁且高效。例如,使用`PIVOT`对上述案例进行列转行的代码如下: ```sql SELECT * FROM f...

    Oracle行列转换_总结

    - **适用版本**: Oracle 10g 及以上 - **操作原理**: 利用 `MODEL` 子句进行行列转换。 - **示例**: ```sql SELECT id, cn, cv FROM t_col_row MODEL RETURN UPDATED ROWS PARTITION BY (ID) DIMENSION BY ...

    orcale数据库 行列互换

    Oracle 11g及更高版本提供了PIVOT功能,使得行转列更加方便。例如,要将上面的“语文”和“数学”成绩用PIVOT实现,可以写成: ```sql SELECT * FROM ( SELECT student, name, score FROM [score] ) PIVOT ( SUM...

    数据库行列转换算法

    Oracle数据库提供了多种方法来实现这种转换,本篇将详细介绍如何在Oracle中进行行列转换,包括列转行、行转列以及各种复杂场景下的转换。 1. 列转行 列转行主要是将数据库表中的多列数据转换为多行数据。在Oracle...

    行列转换总结.pdf

    适用于 Oracle 10g 及以上版本。这种方法利用了 Oracle 的 `MODEL` 子句,该子句主要用于多维数据分析和复杂的数据重排操作。 **示例 SQL**: ```sql SELECT id, cn, cv FROM t_col_row MODEL RETURN UPDATED ROWS ...

    Oracle高级sql学习与练习

    13. Oracle 10G正则表达式扩展了对文本处理的能力,提供了更为强大的文本搜索和替换功能。 14. 使用HINT允许开发者给优化器提供提示,以影响SQL语句的执行计划。 15. PARTITION分区则用于将大表划分为更小、更易于...

    oracle学习参考

    而在Oracle 11g及更高版本,引入了`PIVOT`功能,使得行转列更加直观。`PIVOT`语句允许指定列名和对应的值,生成新的列。 - **列转行**:列转行通常需要使用`UNION ALL`或`UNPIVOT`操作。`UNPIVOT`可以把多列数据...

    通过SQL语句实现行列转换的几种方法

    从Oracle 10g 开始,`wmsys.wm_concat()` 函数提供了更简单的解决方案。这个函数可以自动将多行数据合并为一个以逗号分隔的字符串。尽管这种方法非常直观且易于使用,但它存在一个问题:当查询结果集中有多行数据时...

    Oracle单条SQL语句可以做什么.pdf

    综上所述,Oracle中的单条SQL语句可以通过各种高级功能实现复杂的查询逻辑,包括行列转换、处理重复值以及自定义合计函数等。这些技术的应用不仅能够提高查询效率,还能够简化数据处理流程,为企业提供更高效的数据...

    oracle实现多行合并的方法

    oracle10g以后,提供了一个函数WMSYS.WM_CONCAT,能很轻松实现该功能。 代码如下:select t.rank, WMSYS.WM_CONCAT(t.Name) TIME From t_menu_item t GROUP BY t.rank; 这样,看着就舒服多了。 这个方法没出来之前,...

    通过SQL语句实现行列转换的几种方法.rar_oralce_possiblevxh_southernzw8_sql

    1. **使用PIVOT**:Oracle 11g引入了PIVOT关键字,使得行转列变得更加直观和方便。PIVOT允许我们将某一列的值转换为多列,将原始数据中的行聚合为特定的列。例如,如果我们有一个销售数据表,其中包含产品、月份和...

    事务与分析一体化数据库架构.pptx

    6. **新增混合计算规格**:目前正进行邀测的新规格,如8 core、32 GB、720G SSD,可以轻松扩展至PB级别,且提供强大的SQL支持,包括Oracle的分析函数和层次查询,实现对百亿级大表的毫秒级分析。 7. **便捷的数据...

    PHP基础教程 是一个比较有价值的PHP新手教程!

    本教程并不想让你完全了解这种语言,只是能使你尽快加入开发动态web站点的行列。我假定你有一些HTML(或者HTML编辑器)的基本知识和一些编程思想。 1.简介 PHP是能让你生成动态网页的工具之一。PHP网页文件被当作...

    sqltoy-orm框架系统-其他

    oracle 从oracle11g到19c db2 9.5+,建议从10.5 开始 mysql 支持5.6、5.7、8.0 版本 postgresql 支持9.5 以及以上版本 sqlserver 支持2008到2019版本,建议使用2012或以上版本 sqlite sybase_iq 支持15.4以上版本,...

Global site tag (gtag.js) - Google Analytics