SQL语句中,如果有group by 和order by两个语句,是先分组还是先排序? group by 语句执行后记录会按关键字自动升序吗?

SQL语句中,如果有group by 和order by两个语句,是先分组还是先排序?

group by 语句执行后记录会按关键字自动升序吗?
楚潇离  |  浏览 16104 次   问题未开放回答
推荐于2016-10-21 16:43:02 最佳答案
先进行分组处理。

Group By 和 Having, Where ,Order by这些关键字是按照如下顺序进行执行的:Where, Group By, Having, Order by。

首先where将最原始记录中不满足条件的记录删除(所以应该在where语句中尽量的将不符合条件的记录筛选掉,这样可以减少分组的次数)
然后通过Group By关键字后面指定的分组条件将筛选得到的视图进行分组

接着系统根据Having关键字后面指定的筛选条件,将分组视图后不满足条件的记录筛选掉
最后按照Order By语句对视图进行排序,这样最终的结果就产生了。
在这四个关键字中,只有在Order By语句中才可以使用最终视图的列名,如:

SELECT FruitName, ProductPlace, Price, ID AS IDE, Discount
FROM T_TEST_FRUITINFO
WHERE (ProductPlace = N'china')
ORDER BY IDE
这里只有在ORDER BY语句中才可以使用IDE,其他条件语句中如果需要引用列名则只能使用ID,而不能使用IDE。

尤建波  | 产品经理向TA咨询

擅长: IT

其他回答

肯定是group by先

order by优先级最低,在最后

group by 语句执行后记录会按关键字自动升序?
不一定,group by只负责分组。
 本回答被提问者采纳
flyingFish211    |  发布于2011-04-22 13:13
评论 
15  1
按姓名排序:
select 姓名,SUM(销售额) as 销售 from 销售表 order by 姓名 group by 姓名

按销售排序:
select 姓名,SUM(销售额) as 销售 from 销售表 group by 姓名 order by SUM(销售额) desc
udd1020    |  发布于2011-04-22 13:17
评论 
2  0
这几条关键字 是有先后顺序的.

where.....group by....having.....order by

都是可选..但是如果全部写出来 必须是这个顺序...
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值