- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Oraclegroupby用法实例详解
Group by的语法
Select [filed1,fild2,]聚合函数(filed),
[Grouping(filed),]
[Grouping_id(filed1,filed2,…)]
From tablename
Where condition
[Group by {rollup|cube}(filed,filed2)]
[having condition]
[order by filed1]
一、基本用法:
(1)我们通过几个例子来研究groupby的基本用法
创建测试表
SQL create table sales(
2 empid number, --雇员ID
3 depid number, - -部门ID
4 area varchar(20), --区域
5 salenum number); --销售额
?
表已创建。
?
SQL insert into sales values(1,1,china,10);
SQL insert into sales values(2,1,china,10);
SQL insert into sales values(3,1,china,10);
SQL insert into sales values(3,1,china,10);
SQL insert into sales values(3,1,china,10);
SQL insert into sales values(1,1,china,10);
SQL insert into sales values(2,1,china,10);
SQL insert into sales values(4,2,china,10);
SQL insert into sales values(4,2,china,10);
SQL insert into sales values(5,3,us,10);
SQL insert into sales values(5,3,us,10);
需求1,按部门统计销售额 (简单用法)
SQL select depid,sum(salenum) from sales group by depid;
DEPID SUM(SALENUM)
---------- ------------
1??????? 70
2??????? 20
3??????? 20
需求2,按部门统计销售额,并且只显示销售总额小于30的部门及销售额(使用having子句)
SQL select depid,sum(salenum) totalnum from sales
group by depid
having sum(salenum) 30;
DEPID SUM(SALENUM)
---------- ------------
2??????? 20
3??????? 20
注解:需求2需要使用having字名,而且在子句中不能使用别名,必须使用在select语句中书写的形式
(2)Where 和having的区别
Wheret和having子句都用来筛选数据,但是where是针对原数据进行筛选,而having子句只是针对汇总后的结果进行筛选,所以在需求二的例子中,想要对销售总额进行过滤只能使用having子句
(3)使用order by 排序
SQL select depid,sum(salenum) from sales group by depid;
DEPID SUM(SALENUM)
---------- ------------
1?????? 70
2?????? 20
3?????? 20
注意观察需求1的例子,depid是已经按照在depid升序排列的,这是因为oracle在做聚合统计的时候会首先对字段进行排序,所以最终的结果是按照升序进行排列的,如果order by后跟着多个字段,默认排序是先对第一个字段升序排序,然后再排第二个字段,以此类推,所以如果在应用中仅仅需要长序排序可以不用加order by 参数,毕竟这会影响性能
二、扩展用法:
扩展用法使用下面的表进行实验研究
SQL create table testgroup(
2 a varchar(5),
3 b varchar(5),
4 c varchar(5),
5 n number);
建完测试表,然后插入两条测试数据
SQL insert into testgroup values(a1,b1,c1,10);
SQL insert into testgroup values(a1,b1,c1,20);
我们使用基本的group by 可以得到以下结果
SQL select a,b,c,sum(n) total from testgrou
您可能关注的文档
- MPAcc会计硕士联考逻辑重要考点总结.doc
- MOTO外观检验标准APPEARANCEINSPECTIONCRITERIA.doc
- acm试题分类.doc
- MPS4000B立磨作业指导书.doc
- MRB作业程序指导书.doc
- MP4转MP3格式转换器完美教程.doc
- moto里程碑sd卡教程.doc
- AdobePhotoshop期中考试试卷.doc
- MRP和DRP参考资料.doc
- MSIP35NEO2FR傻瓜超频教程.doc
- CNAS-CL63-2017 司法鉴定-法庭科学机构能力认可准则在声像资料鉴定领域的应用说明.docx
- 12J7-3 河北《内装修-吊顶》.docx
- 12N2 河北省12系列建筑标准设计图集 燃气(油)供热锅炉房工程.docx
- 内蒙古 12S8 排水工程 DBJ03-22-2014.docx
- 山西省 12S10 12系列建筑标准设计 管道支架、吊架.docx
- 16J601-木门窗标准图集.docx
- 12J8 河北省12系列《 楼梯》.docx
- CNAS-GL37 2015 校准和测量能力(CMC)表示指南.docx
- CNAS-RL02-2016 能力验证规则.docx
- 津02SJ601 PVC塑料门窗标准.docx
最近下载
- 品牌策划与推广实战PPT全套完整教学课件.pptx
- 概率论与数理统计课件-全概率与贝叶斯公式.ppt VIP
- 炒茶机及其系统设计.doc
- The Pricing of Options and Corporate Liabilities期权定价与公司负债.pdf
- (概率论与数理统计)全概率公式与贝叶斯公式.ppt VIP
- 新人教(pep)四年级英语下册Unit4 At the Farm A. Let's talk 说课稿.doc
- 职业教育课程建设人工智能赋能的改革研究.docx VIP
- 公司出纳年终工作总结6篇.docx VIP
- (完整word版)AAO工艺设计计算.doc VIP
- 《秘书工作理论与实务》课件——第一章 秘书办文工作.pptx VIP
文档评论(0)