Oracle中使⽤groupby对分组字段进⾏分组,对⾮分组字段进
⾏合并
因为以前⽤的都是MySQL,对Oracle了解并不是太深,所以使⽤Oracle遇坑
在⼯作中,有⼀个很复杂的业务逻辑,需要⽤到四张表,分别是contract,contractrevision,btv,variables。
其中contract和contractrevision需要join拿出所有合同。再利⽤variables定义的153个字段与前两个表字段进⾏拼接,153个字段需要从btv表中取值,并且需要⾏转列,btv表中有1亿3千多万条数据,所以数据量很⼤。取出的结果需要根据合同id和合同版本号进⾏分组,然后将153个字段进⾏合并,并且确定合并后不会出现两条数据。
在Oracle中使⽤group by 时,所有select后⾯的字段都要放到group by 后⾯,除⾮使⽤分析函数。。。
sql语句有两种写法:
1.first_value() over() :取出分区中第⼀条记录的字段值,partition by 可选,order by 可选
select ename,first_value(salary) over(partition by job order by salary desc)
但是这种⽅法被我排除掉了,因为超级慢,⼀亿多条数据跑了三个⼩时,最后报了⼀个临时表空间不⾜,最后让组长加了100G的临时表空间,⼜补充了Oracle的物理空间,然后我⼜优化了⼀下sql,就是第⼆种⽅法。
2,max() : 取分区的最⼤值,对象可以是字符串,根据字典排序。
groupby分组这种⽅法⽐第⼀种⽅法好⼀点,速度⽐第⼀种⽅法快很多,⼤概⼀个多⼩时就能跑完这⼀亿多条数据,如果Oracle临时表空间不⾜,可以添加临时表空间。如果加不了,那就分字段进⾏合并,然后再进⾏join。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。