Oracle多行数据合并为一行数据并将列数据转为字段名三种方式 |
||||||||||||||||||||||||||||||||||||||||
实现查询效果原数据
方式一:MAX()数据效果
SQL根据FZ字段筛选并分组,MAX支持字符内容,SUN()同样支持,但是只能是数字类型 。 SELECT FZ, MAX(CASE WHEN PROJECT = '电脑' THEN VALUE END) 电脑, MAX(CASE WHEN PROJECT = '手机' THEN VALUE END) 手机, MAX(CASE WHEN PROJECT = '导管' THEN VALUE END) 导管 FROM TABLE01 GROUP BY FZ 此方法没有数据库类型限制,MySQL、Oracle、达梦均可 。 方式二:LISTAGG()数据效果
此方法仅仅是合并列内容,便于整合 。 SELECT FZ,LISTAGG(PROJECT,',') PROJECT FROM TABLE01 WHERE FZ = 1; listagg函数是在oracle11g后新增的,是一个实现字符串聚合的内建函数 。也可以实现行转列的功能,将某个字段的多行数据合并成一条 。 用法说明:
方式三:WM_CONCAT()数据效果
此方法与方法二相关相同,但适合于Oracle数据库 。 SELECT FZ,WM_CONCAT(PROJECT,',') PROJECT FROM TABLE01 --WHERE FZ = 1 GROUP BY FZ; 总结到此这篇关于Oracle多行数据合并为一行数据并将列数据转为字段名的文章就介绍到这了,更多相关Oracle多行数据合并一行数据内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持! |