Oracle_group_by_用法實例详解.doc

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Oracle_group_by_用法實例详解

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

文档评论(0)

fv45ffsjjI + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档