group by 的用法[通俗易懂]

group by 的用法[通俗易懂]版权声明:本文为CSDN博主「IT界一股清流」的原创文章,遵循CC4.0BY-SA版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/jerrytomc

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

版权声明:本文为CSDN博主「IT界一股清流」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/jerrytomcat/article/details/82351605

 

1. group by 的解释:

  对哪个字段 ( 哪几个字段)进行分组。

 

2. group by 的用法:

  select 字段 from 表 where 条件 group by 字段1(,字段2,字段3)

  select 字段 from 表  group by 字段1(,字段2,字段3)having 过滤条件

  ps:where 是先过滤,再分组;having 是分组后再过滤

 

3. group by 的案例:

  •   创建student表:

  create table student(

    id, int 

    name,varchar(20)

    grade,varchar(20)

    salary,varchar(20)

  );

  •   向student表中插入数据:

   insert into student values(1,’zhang’,’A’,1500)

   insert into student values(2,’wang’,’B’,3000) 

      insert into student values(3,’liu’,’A’,1500)

      insert into student values(4,’sun’,’A’,3500)

      insert into student values(5,’wu’,’C’,2000)

   insert into student values(6,’xu’,’D’,2500)

  • student 表的结果:
student
id name grade salary
1 zhang A 1500
2 wang B 3000
1 zhang A 1500
4 liu A 3500
5 wu C 2000
6 xu D 2500
  •  单个字段分组
    •   SELECT grade FROM student      

 

grade
A
B
A
A
C
D
    •   SELECT grade FROM student GROUP BY grade
grade
A
B
C
D
  • 多个字段分组
    •   SELECT name,SUM(salary) FROM student GROUP BY name,grade
      •   按照名字和成绩划分,查看相同名字下的工资总和sum()是聚合函数
      • PS: 这里把名字和成绩看成一个整体,只要是name相同,grade不同,就是两条记录
name sum(salary)
zhang 3000
wang 3000
liu 3500
wu 2000
xu 2500

 

 

  • Group By中Select指定的字段限制
    • select后的字段:
      •   要么就要包含在Group By语句的后面,作为分组的依据;
      •        要么就要被包含在聚合函数中。
    •  错误:
      •   SELECT name, salary FROM student GROUP BY name
      •        select 后的字段 salary 不在 group by 后面,所以salary无法显示全部值。
    •  正确1:
      •        SELECT name, salary FROM student GROUP BY name , salary     
      •        select 后的字段 name,salary 都包含在group by 后面,两个字段分组。
    •    正确 2:
      •     SELECT name,MAX(salary) FROM student GROUP BY name
      •        select 后的字段 salary 虽然不在 group by 后面,但是在聚合函数MAX(salary)里面,所以只会有一个值会正确。

 

最后: group by 的具体过程实现,字段合并,聚合函数使用,详见https://blog.csdn.net/qq_35069223/article/details/84343961。

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

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

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


相关推荐

  • 辛格尔顿

    辛格尔顿

    2022年1月1日
    44
  • java图书馆新地址_基于SSM的社区图书馆管理系统的设计与实现[通俗易懂]

    java图书馆新地址_基于SSM的社区图书馆管理系统的设计与实现[通俗易懂]好程序设计擅长JAVA(SSM,SSH,SPRINGBOOT)、PYTHON(DJANGO/FLASK)、THINKPHP、C#、安卓、微信小程序、MYSQL、SQLSERVER等,欢迎咨询在学习社区图书馆管理系统的设计与实现项目的时候,方便日后能及时查阅,在本平台中记录一下社区图书馆管理系统的设计与实现的开发流程。在学习时候的选用了SSM(MYECLIPSE),这个框架…

    2022年7月9日
    82
  • pki体系包括_pct体系简介

    pki体系包括_pct体系简介1:PKI的概念        PKI(publickeyinfrastructure),即公钥基础设施,是一种以数字证书机制为基础,依托应用密码学技术(特别是公钥技术,包括加密、签名等应用技术模式)实施并提供安全服务的具体普遍适用性的网络安全基础设施。2:PKI的功能        一个有效的PKI系统必须是安全的和透明的,它的主要目的是通过自动管理密钥和证书,为用户建立起一个安全的

    2022年8月22日
    10
  • ESLint-的基本介绍[通俗易懂]

    ESLint-的基本介绍[通俗易懂]什么是eslintESLint是一个代码检查工具,用来检查你的代码是否符合指定的规范(例如:=的前后必须有一个空格)。规范行业推荐的规范;在创建项目时,我们使用的是JavaScriptStandardStyle代码风格的规则自定义的规范。你和你的团队可以自行约定一套规范使用ESLint的好处在于:多人协作时代码风格统一eslint是法官,Standard是法律vue-cli工具在创建项目时提供选项,我们前面在创建项目时选中了它,所以它在本项目中是直接生效

    2022年6月18日
    36
  • 如何设置自动切换ip地址

    如何设置自动切换ip地址

    2021年9月18日
    168
  • quicktime player屏幕录制_电脑自带录屏怎么使用

    quicktime player屏幕录制_电脑自带录屏怎么使用Mac电脑用自带软件QuickTimePlayer进行录屏的教程,几步就可以学会,挺简单的。  1、首先,找到并打开QuickTimePlayer软件。可以鼠标右键这个图标,选择“选项”-“在程序坞中保留”,这样,软件就固定在了Dock栏,方便以后打开软件。  2、启动软件后,屏幕顶部左上角出现“QuickTimePlayer”栏目。  3、这时,我们点击屏幕左上角“QuickTimePlayer”栏目右边的“文件”选项,选择“新建屏幕录制”菜单项。  4、这时,屏…

    2025年11月11日
    4

发表回复

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

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