最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oraclegroup语句探究学习笔记

来源:动视网 责编:小采 时间:2020-11-09 13:16:20
文档

Oraclegroup语句探究学习笔记

Oraclegroup语句探究学习笔记:group by语句在Oracle中没有排序功能,必须依靠order by才能实现按照预定结果的排序 1、group by语句在Oracle中没有排序功能,必须依靠order by才能实现按照预定结果的排序 2、group by 的cube扩展 with test as( select 1 id
推荐度:
导读Oraclegroup语句探究学习笔记:group by语句在Oracle中没有排序功能,必须依靠order by才能实现按照预定结果的排序 1、group by语句在Oracle中没有排序功能,必须依靠order by才能实现按照预定结果的排序 2、group by 的cube扩展 with test as( select 1 id


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语句探究学习笔记:group by语句在Oracle中没有排序功能,必须依靠order by才能实现按照预定结果的排序 1、group by语句在Oracle中没有排序功能,必须依靠order by才能实现按照预定结果的排序 2、group by 的cube扩展 with test as( select 1 id
推荐度:
标签: 笔记 语句 oracle
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top