Oracle将多个查询结果以列的形式合并在一起

php中文网
发布: 2016-06-07 16:47:51
原创
2011人浏览过

--问题:查询部门的平均工资 岗位的平均工资 每个部门的每个岗位的平均工资 且将其在一个查询中展示 思路:首先分别查出这三张

--问题:查询部门的平均工资 岗位的平均工资 每个部门的每个岗位的平均工资

且将其在一个查询中展示

 

思路:首先分别查出这三张表 假设为A B C 然后利用两两结合 先将A B结合由于它

们之间没有任何关系 所以想要连接它们需要使用rownum 利用完全外连接和rownum相等 使A B表以字段的形式(而不是以行的形式)连接在一起这样的话就可以实现将不同表中的数据以列的形式合并在一起(之所以这么 麻烦是因为union union all minus intersect是以行的形式将多个查询结果合并在一起的 想要实现以列的形式将多个查询结果合并在一起的话就需要借助rownum和(完全)外连接来实现)解决这个问题的核心就是rownum和完全外连接

具体代码:

select e3.部门平均工资, e3.岗位平均工资, e44.部门岗位平均工资 from

(select e11.部门平均工资, e22.岗位平均工资, rownum rn from

(select e1.部门平均工资, rownum rn from

(select avg(sal) 部门平均工资 from

emp group bydeptno)e1)e11

full join

OpenBMB
OpenBMB

OpenBMB 让大模型飞入千家万户

OpenBMB 198
查看详情 OpenBMB

(select e2.岗位平均工资, rownum rn from

(select avg(sal) 岗位平均工资 from

emp group by job)e2)e22

on e11.rn = e22.rn)e3

full join

(select e4.*, rownum rn from

(select avg(sal) 部门岗位平均工资 from

emp group by deptno,job)e4)e44

on e3.rn = e44.rn;

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号