Oraclegroup语句探究学习笔记
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Oraclegroup语句探究学习笔记,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1818字,纯文字阅读大概需要3分钟。
内容图文
group by语句在Oracle中没有排序功能,必须依靠order by才能实现按照预定结果的排序
1、group by语句在Oracle中没有排序功能,必须依靠order by才能实现按照预定结果的排序
2、group by 的cube扩展
with test as
(
select 1 id,2 name from dual
)
select id,name from test group by cube(id,name);
输出结果为
id name
null null
1 null
null 2
1 2
由此不难看出group by cube的作用是把null引入做一个笛卡尔积,最终显示出来,在有些情况下用起来非常的方便,,在某些情况下可以替代union all,极高的提升效率。其中在数据量比较多的情况下,全空列只出现一次
3、grouping()函数
grouping() 与cube一起使用,用来判断这个值是不是聚合产生的null值,如果是返回1,不是返回零
with test as
(
select 1 id,2 name from dual
)
select id,name from test
group by cube(id,name)
having grouping(id)=1;
输出结果为
id name
null null
null 2
with test as
(
select 1 id,2 name from dual
)
select id,name from test
group by cube(id,name)
having grouping(id)=0;
输出结果为
id name
1 null
1 2
4、grouping_id()函数
grouping_id()在某种程度上与grouping()相似,不同的在于grouping()计算一个表达式返回0或1,而group_id()计算一个表达式,确定其参数中的哪一行被用来生成超聚合行,然后常见一个矢量,并将该值作为整型值返回
with test as
(
select 1 id,2 name from dual
),
cuded as(
select
grouping_id(id,name) gid,
to_char(grouping(id)) id_1,
to_char(grouping(name)) name_1,
decode(grouping(id),1,' id 1') id_2,
decode(grouping(name),1,' name 2') name_2
from test
group by cube(id,name)
)
select
gid,id_1||name_1 dn,id_2,name_2
from
cuded;
结果为:
gid dn id_2 name_2
0 00
1 01 name 2
2 10 id 1
3 11 id 1 name 2
本文永久更新链接地址:
内容总结
以上是互联网集市为您收集整理的Oraclegroup语句探究学习笔记全部内容,希望文章能够帮你解决Oraclegroup语句探究学习笔记所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。