group by 和 order by 的区别 + 理解过程

group by 和 order by 的区别 + 理解过程orderby和groupby的区别order by 和 group by 的区别:1,order by 从英文里理解就是行的排序方式,默认的为升序。 order by 后面必须列出排序的字段名,可以是多个字段名。2,group by 从英文里理解就是分组。必须有“聚合函数”来配合才能使用,使用时至少需要一个分组标志字段。注意:聚合函数是—sum()、count()、…

大家好,又见面了,我是你们的朋友全栈君。

order by 和 group by 的区别

order by 和 group by 的区别:

1,order by 从英文里理解就是行的排序方式,默认的为升序。 order by 后面必须列出排序的字段名,可以是多个字段名。

2,group by 从英文里理解就是分组。必须有“聚合函数”来配合才能使用,使用时至少需要一个分组标志字段。

注意:聚合函数是—sum()、count()、avg()等都是“聚合函数

 

自己慢慢去理解的过程。。。。

为什么group by必须要用聚合函数?自己不断在数据库语句写了,摸索了半个小时,,真是愚钝

数据库表:

group by 和 order by 的区别 + 理解过程

各种语句的测试:

select product from orders 查询所有product列,包括重复的

group by 和 order by 的区别 + 理解过程

 

select product from orders GROUP BY product:查询结果只输出product不同的元素列,不包括重复的

group by 和 order by 的区别 + 理解过程

 

select product,price from orders 查询所有的product列值,包括重复的。如果两个bb合在一起的话,那么price就查不出来 了,如下:

group by 和 order by 的区别 + 理解过程

group by product 将product 相同的元素聚合在一起,去掉重复列,那么price将没有意义

只有 聚合在一起的东西才有意义,如聚合在一起的price之和(sum(price))就有意义了,有点感觉了

group by 和 order by 的区别 + 理解过程

select product,sum(price) from orders GROUP BY product :这样才不会报错。

group by 和 order by 的区别 + 理解过程

select product,sum(price) from orders GROUP BY product

//依照前面的(GROUP BY product)就是按 product分组,那么重复的aa就会聚集在一起,那么如果要继续查找 select product,price 继续查找price的话,price就不存在了。。因为重复的aa聚合在一起了。所以只能用一些聚合函数来玩,sum(price)

————————————————————————————————————————————————————————

那么我group by之后还要筛选一下sum(price) >100的product呢?

一开始我直接这么写的,很正常的思路啊、、

select product,sum(price) from orders where sum(price) GROUP BY product

group by 和 order by 的区别 + 理解过程

 

然后查了一波资料,才知道where后面不能接聚合函数?????!!!!

具体原因:https://blog.csdn.net/w2232097312/article/details/52211201

简短来说是因为:聚合函数是针对结果集进行的,但是where条件并不是在查询出结果集之后运行,所以主函数放在where语句中,会出现错误

那么只能用另外一种方法:havaing。having就是专门为了应付这种情况而发明出来的。。。

select product,sum(price) from orders GROUP BY product HAVING sum(price)>100

换种写法,答案就出来了。。。

group by 和 order by 的区别 + 理解过程

其他 扩展问题。。。

group by不能跟where一起用吗?

可以。注意:where肯定在group by 之前。

一,group by 字句也和where条件语句结合在一起使用。当结合在一起时,where在前,group by 在后。即先对select xx from xx的记录集合用where进行筛选,然后再使用group by 对筛选后的结果进行分组 使用having字句对分组后的结果进行筛选。

二,需要注意having和where的用法区别:

       1.having只能用在group by之后,对分组后的结果进行筛选(即使用having的前提条件是分组)。

       2.where肯定在group by 之前。

       3.where后的条件表达式里不允许使用聚合函数,而having可以。

三,当一个查询语句同时出现了where,group by,having,order by的时候,执行顺序和编写顺序是:

1.执行where xx对全表数据做筛选,返回第1个结果集。

2.针对第1个结果集使用group by分组,返回第2个结果集。

3.针对第2个结果集中的每1组数据执行select xx,有几组就执行几次,返回第3个结果集。

4.针对第3个结集执行having xx进行筛选,返回第4个结果集。

5.针对第4个结果集排序。

再来个order by这就是理解的过程。。。

select product,sum(price) from orders GROUP BY product HAVING sum(price)>100 ORDER BY sum(price);

group by 和 order by 的区别 + 理解过程

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/141214.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java 零拷贝_java clone 深拷贝

    Java 零拷贝_java clone 深拷贝Java零拷贝参考:Java中的零拷贝零拷贝(英语:Zero-copy)技术是指计算机执行操作时,CPU不需要先将数据从某处内存复制到另一个特定区域。这种技术通常用于通过网络传输文件时节省CPU周期和内存带宽。零拷贝技术可以减少数据拷贝和共享总线操作的次数,消除传输数据在存储器之间不必要的中间拷贝次数,从而有效地提高数据传输效率零拷贝技术减少了用户进程地址空间和内核地址空间之间因为上:下文切换而带来的开销传统的IO数据读写如下的例子,Java传统IO和网络编程的一段代码Fi

    2022年9月21日
    0
  • CCS软件下载安装教程

    CCS软件下载安装教程关于CCSCCS是CodeComposerStudio的缩写。是美国德州仪器公司推出的代码开发和调试软件。单片机设计会经常用到这个软件。文章目录CCS软件下载安装教程1.下载1.1主要步骤2.安装1.下载CCS是一款免费的软件。可以去官网下载:http://www.ti.com.cn/tool/cn/CCSTUDIO1.1主要步骤登录网页成功后,出现如下界面:如果觉得英文看着不适应,可以在右上角更改网页语言为“简体中文”。注册TI新用户,如实填写各项信

    2022年4月6日
    440
  • 浅析MySQL中concat及group_concat的使用

    浅析MySQL中concat及group_concat的使用

    2022年2月20日
    47
  • Java static(三) – 静态代码块

    Java static(三) – 静态代码块静态代码块static代码块也叫静态代码块,是在类中独立于类成员的static语句块,可以有多个,位置可以随便放,它不在任何的方法体内JVM加载类时会执行这些静态代码块,如果static代码块有多个,JVM将按照它们在类中出现的先后顺序依次执行它们每个静态代码块只会被执行一次实例说明//父类publicclassParentStatic{privatestaticStringpstr=”父类静态变量”;static{System.o.

    2022年7月16日
    14
  • .apk反编译_apk反编译教程

    .apk反编译_apk反编译教程原文作者:[color=blue][b]lpohvbe[/b][/color]原文地址:[url]http://blog.csdn.net/lpohvbe/article/details/7981386[/url]本人接触不久,有错误望请各位神牛不吝赐教,仅仅希望把自己这段时间研究的东西分享一下,如果可以帮助到有需要的童鞋万感荣幸。欢迎评论转载,但请加上转载来源谢谢!请尊重开发者劳动成果!…

    2022年9月15日
    0
  • 在Ubuntu中安装Pycharm轻松搞定[通俗易懂]

    在Ubuntu中安装Pycharm轻松搞定[通俗易懂]说到Python代码编辑器,那肯定是Pycharm最好用了,当然还有Vscode、Atom也是很不错的选择,下面请跟着我进行Pycharm的安装。下载安装包首先必须访问Jetbrains官方网站下载Linux的安装包Pycharm下载地址本文对应Pycharm版本为pycharm-community-2020.2.2点击Download后下载文件名为pycharm-community-2020.2.2.tar.gz解压安装快捷键Ctrl+Alt+T启动终端进入

    2022年8月25日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号