mysql中的group by 和 having使用

这篇具有很好参考价值的文章主要介绍了mysql中的group by 和 having使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

mysql中的group by 和 having 使用

理论

–sql中的group by 用法解析:
– Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”。
–它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理。
–注意:group by 是先排序后分组;
–举例子说明:如果要用到group by 一般用到的就是“每这个字” 例如说明现在有一个这样的表:每个部门有多少人 就要用到分组的技术
select DepartmentID as ‘部门名称’,
COUNT(*) as ‘个数’ from BasicDepartment group by DepartmentID

–这个就是使用了group by +字段进行了分组,其中我们就可以理解为我们按照了部门的名称ID
–DepartmentID将数据集进行了分组;然后再进行各个组的统计数据分别有多少;
–如果不用count(*) 而用类似下面的语法
select DepartmentID,DepartmentName from BasicDepartment group by DepartmentID

–将会出现错误
–消息 8120,级别 16,状态 1,第 1 行
–选择列表中的列 ‘BasicDepartment.DepartmentName’ 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。
–这就是我们需要注意的一点,如果在返回集字段中,这些字段要么就要包含在Group By语句的后面,
–作为分组的依据;要么就要被包含在聚合函数中。
–出现的错误详解:咱们看看group by 的执行的过程,先执行select 的操作返回一个程序集,
–然后去执行分组的操作,这时候他将根据group by 后面的字段
–进行分组,并且将相同的字段并称一列数据,如果group by 后面没有这个字段的话就要分成好多的数据。
–但是分组就只能将相同的数据分成两列数据,而一列中又只能放入一个字段,所以那些没有进行分组的
–数据系统不知道将数据放入哪里,所以就出现此错误
–目前一种分组情况只有一条记录,一个数据格是无法放入多个数值的,
–所以这里就需要通过一定的处理将这些多值的列转化成单值,然后将其放在对应的
–数据格中,那么完成这个步骤的就是聚合函数。这就是为什么这些函数叫聚合函数(aggregate functions)了

–group by all语法解析:
–如果使用 ALL 关键字,那么查询结果将包括由 GROUP BY 子句产生的所有组,即使某些组没有符合搜索条件的行。
–没有 ALL 关键字,包含 GROUP BY 子句的 SELECT 语句将不显示没有符合条件的行的组。
select DepartmentID,DepartmentName as ‘部门名称’,
COUNT(*) as ‘个数’ from BasicDepartment group by all DepartmentID,DepartmentName

–group by 和having 解释:前提必须了解sql语言中一种特殊的函数:聚合函数,
–例如SUM, COUNT, MAX, AVG等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。
–WHERE关键字在使用集合函数时不能使用,所以在集合函数中加上了HAVING来起到测试查询结果是否符合条件的作用。
create TABLE Table1
(
ID int identity(1,1) primary key NOT NULL,
classid int,
sex varchar(10),
age int,
)

–添加测试数据
Insert into Table1 values(1,‘男’,20)
Insert into Table1 values(2,‘女’,22)
Insert into Table1 values(3,‘男’,23)
Insert into Table1 values(4,‘男’,22)
Insert into Table1 values(1,‘男’,24)
Insert into Table1 values(2,‘女’,19)
Insert into Table1 values(4,‘男’,26)
Insert into Table1 values(1,‘男’,24)
Insert into Table1 values(1,‘男’,20)
Insert into Table1 values(2,‘女’,22)
Insert into Table1 values(3,‘男’,23)
Insert into Table1 values(4,‘男’,22)
Insert into Table1 values(1,‘男’,24)
Insert into Table1 values(2,‘女’,19

–举例子说明:查询table表查询每一个班级中年龄大于20,性别为男的人数
select COUNT(*)as ‘>20岁人数’,classid from Table1 where sex=‘男’ group by classid,age having age>20
–需要注意说明:当同时含有where子句、group by 子句 、having子句及聚集函数时,执行顺序如下:
–执行where子句查找符合条件的数据;
–使用group by 子句对数据进行分组;对group by 子句形成的组运行聚集函数计算每一组的值;最后用having 子句去掉不符合条件的组。
–having 子句中的每一个元素也必须出现在select列表中。有些数据库例外,如oracle.
–having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制。
–having子句限制的是组,而不是行。where子句中不能使用聚集函数,而having子句中可以。
————————————————

测试验证


select * from Table1
mysql中的group by 和 having使用
select classid as ‘班级名称’ , COUNT(*) as ‘所有人数’ from Table1 group by classid

mysql中的group by 和 having使用

select classid as ‘班级名称’ , COUNT(*) as ‘男生人数’ from (select * from Table1 t where sex = ‘男’)Table1 group by classid

mysql中的group by 和 having使用

select COUNT(*)as ‘>20岁男生人数’,classid as '班级’from Table1 where sex=‘男’ group by classid,age having age>20;

mysql中的group by 和 having使用
select COUNT(*)as ‘女生人数’,classid as '班级’from Table1 group by classid,sex having sex = ‘女’;

mysql中的group by 和 having使用

select COUNT(*)as ‘男生人数’,classid as '班级’from Table1 group by classid,sex having sex = ‘男’;
mysql中的group by 和 having使用文章来源地址https://www.toymoban.com/news/detail-474681.html

到了这里,关于mysql中的group by 和 having使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL 中的 distinct 和 group by 哪个效率更高?

    在语义相同,有索引的情况下:group by和distinct都能使用索引,效率相同。 在语义相同,无索引的情况下:distinct效率高于group by。原因是distinct 和 group by都会进行分组操作,但group by可能会进行排序,触发filesort,导致sql执行效率低下。 DISTINCT 用于返回唯一不同的值。

    2024年01月23日
    浏览(40)
  • SQL HAVING 子句详解:在 GROUP BY 中更灵活的条件筛选

    HAVING 子句被添加到SQL中,因为 WHERE 不能与聚合函数一起使用。 HAVING语法 以下是Northwind示例数据库中“Customers”表的一部分选择: CustomerID CustomerName ContactName Address City PostalCode Country 1 Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany 2 Ana Trujillo Emparedados y helados Ana

    2024年02月05日
    浏览(64)
  • Mysql group by使用示例

    总数据: 索引情况:

    2024年02月11日
    浏览(33)
  • 玩转SQL语句之group by 多字段分组查询与having子句,一篇解决你的疑惑!

    分组,顾名思义,分成小组。简而言之就是就是把相同的数据分到一个组。 如下表(表名gb),里面有16条数据,前8条是狗狗,后8条是猫猫. 现在对name这个列进行分组查询 得到结果如下: 我们发现他把原始表分为了两个小组,狗狗小组和猫猫小组。从这可以看出分组查询就

    2023年04月18日
    浏览(42)
  • 【MySQL】MySQL表的增删查改以及聚合函数/group by句子的使用

    语法: 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致 注意,这里在插入的时候,也可以不用指定id(当然,那时候就需要明确插入数据到那些列了),那么mysql会使用默认的值进行自增。 插入两条记录,value_list 数量必须和指定列数量及顺序一致 由于 主键

    2024年01月19日
    浏览(52)
  • 【postgresql 基础入门】分组查询 group by 子句的写法,分组条件过滤having子句的写法,多列的分组以及与join联合的多表分组

    ​ 专栏内容 : postgresql内核源码分析 手写数据库toadb 并发编程 个人主页 :我的主页 管理社区 :开源数据库 座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物. 本文主要分享在postgresql 数据库中对查询结果进行分组group by,以及对分组进行条件过滤having,同时对它

    2024年04月11日
    浏览(49)
  • MySQL使用GROUP BY分组后,获取每组中时间记录最新的行对应的其他字段

    在编写MySQL数据库查询语句时,经常遇到使用GROUP BY分组后,需要获取每组中时间记录最新的行对应的其他字段这一情况。例如下表(t_score): id student course score examdate 1 小张 语文 89.0 2023-06-29 2 小张 数学 90.0 2023-06-29 3 小张 语文 91.0 2024-01-10 4 小张 数学 93.0 2024-01-10 5 小李 语

    2024年01月17日
    浏览(35)
  • mysql GROUP BY 怎么 order by 排序

    在 MySQL 中使用 GROUP BY 子句时,如果需要对结果进行排序,可以使用 ORDER BY 子句来对分组后的结果进行排序。 ORDER BY 子句应该放在 GROUP BY 子句之后,使用逗号来分隔需要排序的列,并在排序列后指定排序顺序。例如: 在这个例子中,SELECT 语句选择了表 table1 中的列 column1 和

    2024年02月16日
    浏览(53)
  • MySQL Group by 优化查询

      使用的是临时表,加文件排序(数据量小用内存排序) 注意:这里加的索引一般不会仅仅是group by后面的字段索引(大多数多少条件是一个以 该字段开头联合索引 ,方便使用覆盖索引或者索引下推)。如果该字段是一个varchar类型, 最好 加个int冗余字段,建立索引的字段,

    2024年02月05日
    浏览(44)
  • MySQL 中 Group By 的用法

    Group By 是一种 SQL 查询语句,常用于根据一个或多个列对查询结果进行分组。在 Group By 子句中指定的列将成为分组依据,而在 Select 子句中指定的列必须是聚合函数(例如 SUM、AVG、COUNT 等)或分组列。 Group By 的语法如下:  SELECT column_name(s) FROM table_name WHERE condition GROUP BY co

    2024年02月13日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包