Mysql数据库的条件查询

一、聚合函数
1.聚合函数的介绍
聚合函数又叫组函数,通常是对表中的数据进行统计和计算,一般结合分组(group by)来使用,用于统计和计算分组数据。

常用的聚合函数:

  1. count(col): 表示求指定列的总行数
  2. max(col): 表示求指定列的最大值
  3. min(col): 表示求指定列的最小值
  4. sum(col): 表示求指定列的和
  5. avg(col): 表示求指定列的平均值

2.求总行数

-- 返回非NULL数据的总行数.
select count(height) from students;
-- 返回总行数,包含null值记录;
select count(*) from students;

3.求最大值

-- 查询女生的编号最大值
select max(id) from students where gender = 2;

4.求最小值

-- 查询未删除的学生最小编号
select min(id) from students where is_delete = 0;

5.求和

-- 查询男生的总身高
select sum(height) from students where gender = 1;
-- 平均身高
select sum(height) / count(*) from students where gender = 1;

6.求平均值

-- 注意:求男生的平均身高, 聚合函数不统计null值,平均身高可能有误
select avg(height) from students where gender = 1;
-- 求男生的平均身高, 包含身高是null的
select avg(ifnull(height,0)) from students where gender = 1;
说明
ifnull函数: 表示判断指定字段的值是否为null,如果为空使用自己提供的值。

聚合函数的注意点:
聚合函数默认忽略字段为null的记录 要想列值为null的记录也参与计算,必须使用ifnull函数对null值做替换。

二、分组查询

  1. 分组查询介绍
    分组查询就是将查询结果按照指定字段进行分组,字段中数据相等的分为一组。
分组查询基本的语法格式如下:GROUP BY 列名 [HAVING 条件表达式] [WITH ROLLUP]
说明:
列名: 是指按照指定字段的值进行分组。
HAVING 条件表达式: 用来过滤分组后的数据。
WITH ROLLUP:在所有记录的最后加上一条记录,显示select查询时聚合函数的统计和计算结果
  1. group by的使用
    group by可用于单个字段分组,也可用于多个字段分组
-- 根据gender字段来分组
select gender from students group by gender;
-- 根据name和gender字段进行分组
select name, gender from students group by name, gender;
  1. group by + group_concat()的使用
    group_concat(字段名): 统计每个分组指定字段的信息集合,每个信息之间使用逗号进行分割
-- 根据gender字段进行分组, 查询gender字段和分组的name字段信息
select gender,group_concat(name) from students group by gender;
  1. group by + 聚合函数的使用
-- 统计不同性别的人的平均年龄
select gender,avg(age) from students group by gender;
-- 统计不同性别的人的个数
select gender,count(*) from students group by gender;
  1. group by + having的使用
    having作用和where类似都是过滤数据的,但having是过滤分组数据的,只能用于group by
-- 根据gender字段进行分组,统计分组条数大于2的
select gender,count(*) from students group by gender having count(*)>2;
  1. group by + with rollup的使用
    with rollup的作用是:在最后记录后面新增一行,显示select查询时聚合函数的统计和计算结果
-- 根据gender字段进行分组,汇总总人数
select gender,count(*) from students group by gender with rollup;
-- 根据gender字段进行分组,汇总所有人的年龄
select gender,group_concat(age) from students group by gender with rollup;

总结:

  • count(col): 表示求指定列的总行数
  • max(col): 表示求指定列的最大值
  • min(col): 表示求指定列的最小值
  • sum(col): 表示求指定列的和
  • avg(col): 表示求指定列的平均值
  • group by 根据指定的一个或者多个字段对数据进行分组
  • group_concat(字段名)函数是统计每个分组指定字段的信息集合
  • 聚合函数在和 group by 结合使用时, 聚合函数统计和计算的是每个分组的数据
  • having 是对分组数据进行条件过滤
  • with rollup在最后记录后面新增一行,显示select查询时聚合函数的统计和计算结果

Mysql数据库的条件查询(聚合函数、分组查询)相关推荐

  1. MySQL数据库——day26 数据库安装,卸载,概念,msq的介绍,安装,连接,DDL,DML,DQL模糊查询,字段控制(别名和运算),排序,聚合函数,分组查询(where和having),分页查询

    学到mysql的时候非常的快,感觉前面的没有很巩固,还是要复习前面的博客 常见的数据库 MySQL , Oracle , SQL Server , SQLite , DB2 , - SQL Serve ...

  2. tp5使用sum()聚合函数分组查询

    数据查询出来大概是这个样子(实际应用中会很复杂,这里造一些类似的数据,用来举例说明) 简单的查询 $data = Db::name('order')->field('sum(money) as ...

  3. 97. python高级------MySQl数据库的条件查询

    文章目录 97. python高级------MySQl数据库的条件查询 python修炼第二十四天 2019年 4月 23日 晴 1. 聚合函数的介绍 2. 求总行数 3. 求最大值 4. 求最小值 ...

  4. sql数据库查询聚合函数_如何使用SQL Server数据质量服务确保正确的数据聚合

    sql数据库查询聚合函数 介绍 (Introduction) An interesting opportunity arose at a client site during early Octobe ...

  5. Django学习笔记(3):使用模型类进行查询(查询函数、F对象、Q对象、聚合函数、查询集、模型类关系、关联查询、自关联、管理器)

    文章目录 1.查询函数 2.F对象 3.Q对象 4.聚合函数 5.Count函数 6.查询集 查询集的特性 对查询集进行切片 判断一个查询集中是否有数据 7.模型类之间的关系 一对多关系 多对多关系 ...

  6. Mysql数据库基本操作(七)多表查询-子查询,表自身关联查询

    多表查询还有前面的两块内容--内连接查询,外连接查询,希望看到这篇博客的朋友先去看看我的"Mysql数据库"专栏中Mysql数据库基本操作(六)多表查询-内连接,外连接这一章博客, ...

  7. 数据库编程1 Oracle 过滤 函数 分组 外连接 自连接

    [本文谢绝转载原文来自http://990487026.blog.51cto.com] <大纲>数据库编程1 Oracle 过滤 函数 分组 外连接 自连接本文实验基于的数据表:winso ...

  8. Mysql数据库基本操作(六)多表查询-内连接查询,外连接查询

    数据准备 use mydb3 ; --创建部门表 create table if not exists dept3 ( deptno varchar (20) primary key , --部门号 ...

  9. Mysql数据库(八)排名函数

    Mysql数据库(八)排名函数 mysql中排名函数有三个 1.row_number():表示排序,成绩相同,也不重复 2.rank():表示排序,成绩相同,排名重复,但跳跃 3.dense_rank ...

最新文章

  1. 理解 IntelliJ IDEA 的项目配置和Web部署
  2. Nature:“解构”母爱
  3. SQLServer · 最佳实践 · RDS for SQL Server 2012 权限限制的提升与改善
  4. python中bin函数的用法_Python 3标准库用法--ascii()、bin()、breakpoint()函数
  5. 124 Binary Tree Maximum Path Sum
  6. JavaScript 技术篇-js字符串大小写转换,toLocalUpperCase()和toUpperCase()的区别详解
  7. java就业培训教程 第一章读书笔记
  8. String 属于基础的数据类型吗?
  9. 魅族魅蓝5s详细开启Usb调试模式的流程
  10. linux监控任务跑满,Linux服务器带宽和CPU跑满或跑高排查
  11. Maven多模块打包遇到的问题详解
  12. python从入门到精通需要多久-python学习从入门到精通要多久
  13. 5555555,老粘不上来。。
  14. kpi绩效考核流程图_某集团公司完整KPI绩效考核方案(PPT)
  15. 面试一个应届生,从不起眼到令人刮目相看
  16. 交换机,集线器,路由器这三者如何区分,各自的作用是什么?
  17. CSS 文本字体颜色设置方法。
  18. linux修改组群名字,Linux用户和组 - 回忆斑斑驳驳的个人空间 - OSCHINA - 中文开源技术交流社区...
  19. PHP把html代码转换成普通字符串,在页面中显示
  20. 简述Veeam备份原理和组件功能

热门文章

  1. 项目分享| DIY STM32控制的电子负载(硬件方案分享,软件代码下载)
  2. JS如何将 DOM 生成图片并下载
  3. 我的HIFI WAV 播放器设计之三电路图DAC及模拟信号处理电路部分
  4. python怎么做https请求_Python使用https请求的方法
  5. “ windows套接字初始化失败”解决方法
  6. 恒生电子软件测试工程师工资,【武汉恒生电子工资】软件测试工程师待遇-看准网...
  7. 无人豆浆机?九阳,请开始你的表演
  8. 流程智能管理为何对现代企业来说至关重要?
  9. beehive 源码阅读- go 语言的自动化机器
  10. 安全基础--29--Grails开发基础操作与配置