当前位置: 首页 > news >正文

Oracle多行数据合并为一行数据,并将列数据转为字段名

Oracle多行数据合并为一行数据

  • 实现查询效果
    • 原数据
  • 方式一:MAX()
    • 数据效果
    • SQL
  • 方式二:LISTAGG()
    • 数据效果
  • 方式三:WM_CONCAT()
    • 数据效果

实现查询效果

原数据

FZPROJECTVALUE
1电脑$1600
1手机$12
1导管$1
2电脑$2
2手机$22

方式一:MAX()

数据效果

电脑电脑手机导管
1$1600$12$1
2$2$22

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()

数据效果

FZPROJECT
1电脑,手机,导管

此方法仅仅是合并列内容,便于整合。

SELECT FZ,LISTAGG(PROJECT,',') PROJECT 
FROM TABLE01 
WHERE FZ = 1;

方式三:WM_CONCAT()

数据效果

FZPROJECT
1电脑,手机,导管
2电脑,手机

此方法与方法二相关相同,但适合于Oracle数据库。

SELECT FZ,WM_CONCAT(PROJECT,',') PROJECT 
FROM TABLE01 
--WHERE FZ = 1
GROUP BY FZ;
http://www.lryc.cn/news/111893.html

相关文章:

  • MySQL5.7 与 MariaDB10.1 审计插件兼容性验证
  • PyTorch Lightning教程五:Debug调试
  • 末流211无科研保研经验分享
  • 日期选择器多选换行
  • NodeJS原型链污染ctfshow_nodejs
  • 18. SpringBoot 如何在 POM 中引入本地 JAR 包
  • vue2-$nextTick有什么作用?
  • python自动收集粘贴板
  • Vue3_语法糖—— <script setup>以及unplugin-auto-import自动引入插件
  • 2023-08-06力扣做过了的题
  • 进程间通信之管道
  • f12 CSS网页调试_css样式被划了黑线怎么办
  • vue-制作自动滚动效果
  • [国产MCU]-BL602-开发实例-DMA数据传输
  • Redis压缩列表
  • 【SA8295P 源码分析】62 - Android GVM Kernel 内核 make bootimage 过程分析
  • 机器学习——SMO算法推导与实践
  • mac的终端通过code .指令快速启动vscode
  • 前端系统使用iframe下载文件
  • RabbitMQ - 简单案例
  • 《吐血整理》高级系列教程-吃透Fiddler抓包教程(30)-Fiddler如何抓Android7.0以上的Https包-番外篇
  • 服务器被攻击了怎么办?
  • P1156 垃圾陷阱(背包变形)
  • [Docker实现测试部署CI/CD----构建成功后钉钉告警(7)]
  • UE5 半透明覆层材质
  • 在Raspberry Pi 4上安装Ubuntu 20.04 + ROS noetic(不带显示器)
  • CommStudio for .NET Crack
  • 蓝桥杯上岸考点清单 (冲刺版)!!!
  • AI一键生成短视频
  • 基于MATLAB长时间序列遥感数据分析(以MODIS数据处理为例)