oracle行转列是什么?动态行转不定列
(资料图片)
/*物料 需要数量 需要仓库 现存量仓库 现存量仓库数量 批次 A1 2 C1 C1 20 123 A1 2 C1 C2 30 111 A1 2 C1 C2 20 222 A1 2 C1 C3 10 211 A2 3 C4 C1 40 321 A2 3 C4 C4 50 222 A2 3 C4 C4 60 333 A2 3 C4 C5 70 223 我需要把上面的查询结果转换为下面的。 物料 需要数量 需要仓库 C1 C2 C3 C4 C5 A1 2 C1 20 50 10 0 0 A2 3 C4 40 0 0 110 70 */ ---------------------------------------------------------------建表 ----------------判断表是否存在 declare num number; begin select count(1) into num from user_tables where table_name="TEST"; if num>0 then execute immediate "drop table TEST"; end if; end; ----------------建表 CREATE TABLE TEST( WL VARCHAR2(10), XYSL INTEGER, XYCK VARCHAR2(10), XCLCK VARCHAR2(10), XCLCKSL INTEGER, PC INTEGER ); ----------------第一部分测试数据 INSERT INTO TEST VALUES("A1", 2, "C1", "C1" , 20, 123); INSERT INTO TEST VALUES("A1", 2, "C1", "C2" , 30, 111); INSERT INTO TEST VALUES("A1", 2, "C1", "C2" , 20, 222); INSERT INTO TEST VALUES("A1", 2, "C1", "C3" , 10, 211); INSERT INTO TEST VALUES("A2", 3, "C4", "C1" , 40, 321); INSERT INTO TEST VALUES("A2", 3, "C4", "C4" , 50, 222); INSERT INTO TEST VALUES("A2", 3, "C4", "C4" , 60, 333); INSERT INTO TEST VALUES("A2", 3, "C4", "C5" , 70, 223); COMMIT; --select * from test; ---------------------------------------------------------------行转列的存储过程 CREATE OR REPLACE PROCEDURE P_TEST IS V_SQL VARCHAR2(2000); CURSOR CURSOR_1 IS SELECT DISTINCT T.XCLCK FROM TEST T ORDER BY XCLCK; BEGIN V_SQL := "SELECT WL,XYSL,XYCK";
FOR V_XCLCK IN CURSOR_1 LOOP V_SQL := V_SQL || "," || "SUM(DECODE(XCLCK,""" || V_XCLCK.XCLCK || """,XCLCKSL,0)) AS " || V_XCLCK.XCLCK; END LOOP; V_SQL := V_SQL || " FROM TEST GROUP BY WL,XYSL,XYCK ORDER BY WL,XYSL,XYCK"; --DBMS_OUTPUT.PUT_LINE(V_SQL); V_SQL := "CREATE OR REPLACE VIEW RESULT AS "|| V_SQL; --DBMS_OUTPUT.PUT_LINE(V_SQL); EXECUTE IMMEDIATE V_SQL; END; ----------------------------------------------------------------结果 ----------------执行存储过程,生成视图 BEGIN P_TEST; END; ----------------结果 SELECT * FROM RESULT T; WL XYSL XYCK C1 C2 C3 C4 C5 ---------- --------------------------------------- ---------- ---------- ---------- ---------- ---------- ---------- A1 2 C1 20 50 10 0 0 A2 3 C4 40 0 0 110 70
----------------第二部分测试数据 INSERT INTO TEST VALUES("A1", 2, "C1", "C6" , 20, 124); INSERT INTO TEST VALUES("A2", 2, "C1", "C7" , 30, 121); INSERT INTO TEST VALUES("A3", 2, "C1", "C8" , 20, 322); COMMIT; ----------------报告存储过程,生成视图 BEGIN P_TEST; END; ----------------结果 SELECT * FROM RESULT T; WL XYSL XYCK C1 C2 C3 C4 C5 C6 C7 C8 ----- ----- -------- ------- -------- ---------- ---------- ---------- ---------- ---------- ---------- A1 2 C1 20 50 10 0 0 20 0 0 A2 2 C1 0 0 0 0 0 0 30 0 A2 3 C4 40 0 0 110 70 0 0 0 A3 2 C1 0 0 0 0 0 0 0 20 --------------- 删除实体 DROP VIEW RESULT; DROP PROCEDURE P_TEST; DROP TABLE TEST;
标签: 存储过程
相关推荐:
最新新闻:
- 如何把脑电信号转换成功率谱?matlab脑电信号特征提取程序|天天速讯
- 当前观点:机械迷城有哪些技巧?机械迷城攻略2
- 全球热文:如何把真实的文件隐藏到一张图背后?内涵图制作
- OpenCV学习笔记 再谈OpenCV数据结构Mat详解:每日快报
- 【技术】基于SIP协议的语音通信技术
- 世界快看:数据库编程 NET和SQLServer中“空值”辨析
- MyEclipse 8.5 注册码
- 有没有MAC的WPS?金山公司明年将有全平台的WPS:全球热门
- 今日看点:安卓手机如何设置便携式WLAN热点?设置教程
- 利勃海尔冰箱怎么样?利勃海尔冰箱有哪些优势?_全球速看料
- Trinity是什么?AMDTrinityAPU最新发布
- 怎么把Word转PDF格式?转换方法步骤
- 100幅出名的视觉欺骗图片 你从图中看到了什么?
- 三星S6358怎么刷机?三星S6358移动定制版完整刷机教程|实时焦点
- 华为g9怎么样?华为g9参数配置评测
- 渲染农场:分布式并行集群计算系统
- hotel california加州旅馆中英对照歌词|热点评
- win10系统显示不了桌面怎么回事?解决步骤如下_今日精选
- excel/word如何快速输入当前的时间和日期?输入方法技巧
- SCM供应链管理系统为企业带来哪些益处?SCM供应链管理系统介绍
- office怎么卸载?office卸载步骤-天天时讯
- oracle行转列是什么?动态行转不定列
- 世界播报:自然语言处理NLP的数学基础
- 微信聊天记录怎么导出?微信聊天记录导出方法 环球观天下
- 天天头条:dr.dre耳机怎么样?dr.dre耳机简介及价格
- 数据透视表是什么?excel中数据透视表的基本概念 世界今热点
- 全球消息!新倩女幽魂哪个区人最多?2020倩女幽魂哪个区人多?
- 电脑扫描文件怎么弄?微信一物一码怎么开通? 环球关注
- 全球观速讯丨如何在微信小程序上开发一个蚂蚁森林和蚂蚁庄园结合体?开发方法步骤
- Word转PDF用什么软件?全能PDF转换助手-全球观点
- 热门看点:Win8如何开启802.1x网络认证?Win8设置和修改系统电源方案的方法
- 安卓手机耗电快、待机时间短怎么办?解决办法
- 【新要闻】C语言输出a大于100,C语言:ALGOL代码实现“水仙花数”
- 数控铣床法兰克系统代码完整版 数控铣床法兰克系统代码大全
- 每日精选:网盘哪个好?网盘性能推荐
- 环球观天下!华为P50有哪些配置?华为P50参数配置介绍
- 【全球报资讯】荣耀MagicBook14用什么处理器?MagicBook14处理器介绍
- 天天安卓模拟器是什么?安卓模拟器电脑版下载
- n95手机怎么样?n95手机详细测评:今日讯
- 即时焦点:一文读懂程序化交易、算法交易、量化投资、高频交易
- 重磅!2022年第四届全国高校计算机能力挑战赛决赛晋级公示:世界看热讯
- 魔兽世界怀旧服:炼金术(350)技术介绍
- 环球报道:java基础知识:标签和target的属性
- 焦点关注:编辑好正文和引用内容的文本如何添加?
- 什么是沙盒游戏?沙盒类游戏哪十大排行?
- C++/MFC串口通信——光源控制器控制
- Linux下常见的锁机制-自旋锁 自旋锁spinlock见解
- typec数据线是什么?Type-C数据线有哪些优势?:每日播报
- 奖学金名称都有哪些?奖学金名称中英文对照表:焦点短讯
- 世界观察:苹果care是什么意思?苹果care的含义
- 全球动态:电脑蓝牙管理软件工具有哪些?好用的蓝牙管理工具推荐
- 重磅!2022年第四届全国高校计算机能力挑战赛决赛晋级公示:世界看热讯
- 库尔勒经济开发区:电子政务“一站式”服务平台 焦点速看
- Linux下常见的锁机制-自旋锁 自旋锁spinlock见解
- 环球快看点丨什么是静电耳机? 静电耳机和普通耳机什么区别?
- 数控铣床法兰克系统代码完整版 数控铣床法兰克系统代码大全
- cmake-3.19.6-Linux自解压程序 简单的自解压程序|天天动态
- PSAM部分的硬件设计 PSAM部分的硬件设计图
- Word转PDF用什么软件?全能PDF转换助手-全球观点
- 即时焦点:一文读懂程序化交易、算法交易、量化投资、高频交易
- 日本政府奖励民众搬出东京:每个孩子补助100万日元
- 天天滚动:梅西C罗姆巴佩等众星发文缅怀球王:安息吧!贝利
- 天天资讯:Konami:2023年将会公布更多游戏
- 《重型建筑工》steam页面上线 支持简体中文-天天热资讯
- 《潜行者2》新截图发布 多人模式发售后免费更新-每日视点
- 环球简讯:《最后的生还者》剧集新剧照 乔尔和女儿莎拉登场
- 任天堂欧服eShop开启新年折扣 多款大作参与活动_当前消息
- 小米手机如何刷机?小米手机刷机教程步骤
- 打印机硒鼓的寿命一般多久?硒鼓多久换一次?
- 开机后桌面显示慢怎么办? 电脑桌面刷新很慢解决方法
- 双通道内存有什么好处?双通道内存好处介绍
- 图省事、紧裤腰,65亿用户规模,影视OST怎么失灵了?|全球观点
- 被覆盖的文件如何恢复?不小心把文件覆盖了怎么恢复?
- 防火墙ddos防御设置 windows防火墙ddos
- IE浏览器在电脑哪里?查找IE浏览器的方法
- 清空浏览器缓存怎么操作?清理浏览器历史浏览记录方法
- 两寸证件照尺寸是多少?二寸证件照快速制作步骤
- 如何设置开机u盘启动?开机优先启动u盘
- kdh是什么文件?kdh文件怎么转换成word文件
- 什么是dns服务器?设置DNS提升网速方法
- 云手机是什么东西?云手机用途
- 手机没有信号无服务是怎么回事?手机没信号解决思路
- 电脑虚拟内存不足怎么解决?教你彻底清理C盘垃圾
- 打印机墨水怎么加?佳能型号打印机加墨水教程
- 固态硬盘怎么安装?固态硬盘安装后需要怎么设置?