sql:常用:group by 多个字段「建议收藏」

sql:常用:group by 多个字段「建议收藏」首先groupby的简单说明:  groupby一般和聚合函数一起使用才有意义,比如countsumavg等,使用groupby的两个要素:  (1)出现在select后面的字段要么是是聚合函数中的,要么就是groupby中的.  (2)要筛选结果可以先使用where再用groupby或者先用groupby再用having下面看下groupb…

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

首先group by 的简单说明:
   group by 一般和聚合函数一起使用才有意义,比如 count sum avg等,使用group by的两个要素:
   (1) 出现在select后面的字段 要么是是聚合函数中的,要么就是group by 中的.
   (2) 要筛选结果 可以先使用where 再用group by 或者先用group by 再用having
下面看下 group by多个条件的分析:
在SQL查询器输入以下语句
create table test
(
a varchar(20),
b varchar(20),
c varchar(20)
)
insert into test values(1,’a’,’甲’)
insert into test values(1,’a’,’甲’)
insert into test values(1,’a’,’甲’)
insert into test values(1,’a’,’甲’)
insert into test values(1,’a’,’乙’)
insert into test values(1,’b’,’乙’)
insert into test values(1,’b’,’乙’)
insert into test values(1,’b’,’乙’)
第一次查询

select * from test; 结果如下图:

sql:常用:group by 多个字段「建议收藏」

结果中 按照b列来分:则是 5个a 3个b.

按照c列来分:则是 4个甲 4个乙.

第二次 按照 b列来分组 代码如下
select   count(a),b from test group by b (可以想想把b列作为类似key主键,让它唯一,看看分几组)

sql:常用:group by 多个字段「建议收藏」

第三次 按照 c列来分组 代码如下
select count(a),c from test group by c(可以想想把c列作为类似key主键,让它唯一,看看分几组)

sql:常用:group by 多个字段「建议收藏」

第四次 按照 b c两个条件来分组
select count(a),b,c from test group by b,c (可以想想把b和c列一起作为类似key主键,让它唯一,看看分几组)

sql:常用:group by 多个字段「建议收藏」

第五次 按照 c b 顺序分组
select count(a),b,c from test group by c,b (可以想想把c和b列一起作为类似key主键,让它唯一,看看分几组)

sql:常用:group by 多个字段「建议收藏」

可以看出 group by 两个条件的工作过程:
先对第一个条件b列的值 进行分组,分为 第一组:1-5, 第二组6-8,

然后又对已经存在的两个分组用条件二 c列的值进行分组,发现第一组又可以分为两组 1-4,5

第四次和第五次查询结果的区别:

按照 b c两个条件来分组,先对第一个条件b列的值 进行分组,分为 第一组:1-5, 第二组6-8,

然后又对已经存在的两个分组用条件二 c列的值进行分组,发现第一组又可以分为两组 1-4,5。
按照 c b两个条件来分组,先对第一个条件c列的值 进行分组,分为 第一组:1-4, 第二组5-8,

然后又对已经存在的两个分组用条件二 b列的值进行分组,发现第二组又可以分为两组 5, 6-8。

参考:https://blog.csdn.net/qq_27495157/article/details/76828525

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

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

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


相关推荐

  • 天翼网关设置为桥接模式_天翼网关桥接模式

    天翼网关设置为桥接模式_天翼网关桥接模式前两年将家里的电信宽带升级到光纤,光猫也随之进行了升级,当时升级好后,电信工作人员介绍说新的光猫带有wifi功能,如果连接路由器可以不用配置路由器的拨号设置,说是升级到光纤后可以直接连接网线上网,不用再拨号了。当时也没怎么在意,网线连上路由器之后,果然没做宽带的账号设置就可以正常上网了。最近在使用一个软件客户端的时候需要设置宽带拨号的方式更换IP才能使用某个功能,然后才发现家里的宽带升级到光纤后,无法使用原来的拨号方式上网了。通过网络搜索,是因为升级光纤后,将连接的模式设置为路由模式,导致无法使用拨号上

    2025年7月15日
    5
  • VisualSVN Server启动错误(0x8007042a)

    VisualSVN Server启动错误(0x8007042a)

    2021年9月21日
    55
  • SpringMVC 执行流程

    SpringMVC 执行流程springMVC(javaweb开发框架)1、MVC三层架构:模型(service、dao)、视图(JSP等)、控制器(Controller)什么是mvc?*MVC是模型、视图、控制器的简写,是一种软件设计规范*是将业务逻辑、数据、显示分离的方法来组织代码*MVC主要的作用就是降低了控制器(Controller)和视图(View)之间的双向耦合度*MVC不是一种设计模式、MVC是一种架构模式。当然不同的MVC存在着差异Model(数据模型):提供要展示的数据。因此包含数据和

    2022年6月28日
    26
  • flatMap示例

    flatMap示例flatMap示例什么是flatMap()回顾下面的数据结构,#Stream<String[]>#Stream<Stream<String>>#String[][][[1,2],[3,4],[5,6]]在Java8中,我们可以使用flatMap将上述数据结构转化为一下结构#Stream<String>#String[][1,2,3,4,5,6]为什么要平流处理包含超过一个级别的流,例

    2022年6月1日
    34
  • Asp.net Session 与Cookie的应用

    写程序的很多人都知道的,Session是服务器端的东西而Cooike是客户端的东西。因为B/S模式是无状态模式,它们的应用都是要存储客户端的某些登录或是加密的信息。Session存在于服务器端,当然

    2021年12月27日
    41
  • 【剑指Offer学习】【面试题19 :二叉树的镜像】[通俗易懂]

    【剑指Offer学习】【面试题19 :二叉树的镜像】

    2022年2月3日
    48

发表回复

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

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