oracl 多条数据oracle列合并成一列显示

Xshell6破解版亲测可用,分享给大家直接解压即可使用

}

oracle 如何聚合多行函数

在BEA论坛上看一位"专家"写的大作,一条SQL语句是

其实之前有好多这样的问题,但没有一个好的方案,都是嵌套太多,性能损失很大,把三条记录的结果oracle列合并成一列.如果最后的sql语句中的select超过三次,那真的还不如直接这样查询.

不过首先这个方法是错误的,因为这三次都在原表中查询,性能损失很大,其实如果是5条,10條,20条,100条.这样的语句写起来就累死人了.

之前有人提供了几个方案,但都是连成字符串还不是形成多列.真正形成多列应该是用分析函数:

这样实际仩只能原表做一次查询,然后得到的结果集在显示的时候被提前到一行上形成多列.


  

这样原来的行数越多节省的性能越高,因为实际原表查询只囿一次,后来只是对内存中的结果做oracle列合并成一列.上面的那个例子就是



  

}

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

且将其在一个查询中展示

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

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

}

我要回帖

更多关于 oracle列合并成一列 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信