一、分组函数

功能:统计信息

分类:

  • sum求和
  • avg平均值
  • max最大值
  • min最小值
  • count计算个数

特点

  1. 参数支持类型
函数 参数支持类型
sum avg 具有可加性的数据
max min 具有可比较性的数据
count 计数`非空的数据个数,都支持
  1. 都忽略null
  2. 可以搭配distinct使用

1. 各函数的简单使用

获取平均工资和工资总和:

SELECT SUM(salary) FROM employees;
SELECT AVG(salary) FROM employees;



SELECT  SUM(salary) 总工资, ROUND(AVG(salary),2) 平均工资, MIN(salary) 最低工资,
MAX(salary) 最高工资, COUNT(salary) 总数
FROM employees;

2. 搭配distinct的使用

SELECT	COUNT(DISTINCT job_id) AS 工种数量, COUNT(job_id)
FROM employees;

3. COUNT 统计行数

SELECT COUNT(*) FROM employees;

加入常量值1,相当于加入一列的常量值后统计个数

SELECT COUNT(1) FROM employees;

4. 和分组函数一同查询的字段要求是group by后的字段

SELECT AVG(salary),salary
FROM employees;#(×)

二、分组查询

SELECT 	xxx字段,分组函数	<--
FROM 表
[WHERE condition]
GROUP BY xxx字段 <-- 按xxx字段分组(相同值为一组)
[ORDER BY xx]

分组查询中,SELECT的字段需要和GROUP BY后的字段对应

实际执行流程:

  1. 按照xxx字段(或函数等)进行分组
  2. 对每个分组进行按分组函数进行特定的统计
  3. 返回每个组的统计结果

1. 简单应用

查询每个工种最高工资

SELECT 	 job_id, MAX(salary)
FROM employees
GROUP BY job_id;

统计每个位置(城市)的部门个数

SELECT 	 location_id, COUNT(1)
FROM departments
GROUP BY location_id;

2. 添加筛选条件

数据源 位置
分组前筛选 原始表 GROUP BY
分组后筛选 分组后的结果集 GROUP BY

① 分组前的筛选

统计各个上级的下属有奖金的员工的最高工资

SELECT 	 manager_id, MAX(salary)
FROM employees
WHERE commission_pct IS NOT NULL
GROUP BY manager_id;

② 分组后的筛选

使用HAVING语句:

SELECT 	xxx字段,分组函数
FROM 表
[WHERE condition]
GROUP BY xxx字段
[ORDER BY xx]
HAVING xxx条件 <--在最后添加

查询哪个部门的员工个数>2

  1. 查询每个部门的员工个数
SELECT 		department_id, COUNT(1) AS cnt
FROM employees
GROUP BY department_id;
  1. 1的结果进行筛选(员工个数>2)
SELECT 		department_id, COUNT(1) AS cnt
FROM employees
GROUP BY department_id
HAVING cnt>2;

查询领导编号>102的,每个其手下员工的最低工资>5000,满足条件的领导的对应编号

SELECT 	 manager_id, MIN(salary) AS 手下员工最低工资
FROM employees
WHERE manager_id > 102
GROUP BY manager_id
HAVING MIN(salary) > 5000

3. 按表达式或函数分组

员工姓名的长度分组,查询每一组员工个数,筛选员工个数>5的有哪些

SELECT	LENGTH(last_name) as NameLength, COUNT(1) as cnt
FROM employees
GROUP BY NameLength
HAVING cnt > 5
ORDER BY NameLength

4. 按多个字段分组

查询每个(部门,工种)的员工的平均工资

SELECT CONCAT( "(", department_id, ", ", job_id,")" ), AVG(salary)
FROM employees
GROUP BY department_id, job_id;

添加排序和筛选:

SELECT	CONCAT( "(", department_id, ", ", job_id,")" ), AVG(salary)
FROM employees
WHERE department_id IS NOT NULL
GROUP BY department_id, job_id
HAVING AVG(salary)>10000
ORDER BY AVG(salary) DESC;

SQL语句(三)分组函数和分组查询的更多相关文章

  1. 2019-1-11 SQL语句汇总——聚合函数、分组、子查询及组合查询

  2. 逆袭之旅DAY14.东软实训.Oracle.多表连接、分组函数、子查询

    2018-07-10 08:29:55 思考应用场景 异常数据的测试 6.显示能挣得奖金的雇员的姓名.工资.奖金,并以工资和奖金降序排列.select ename,sal,commfrom empWH ...

  3. 常用sql语句总结(一)(查询)

    常用sql语句总结(一)(查询) 数据操作语句:DML 数据定义语句:DDL 数据控制语句:DCL (执行顺序------序号) 一.基本查询: 1. SELECT * ----- 2 FROM 数据 ...

  4. SQL 语句转换格式函数Cast、Convert 区别

    SQL 语句转换格式函数Cast.Convert CAST和CONVERT都经常被使用.特别提取出来作为一篇文章,方便查找. CAST.CONVERT都可以执行数据类型转换.在大部分情况下,两者执行同 ...

  5. SQL Server参数化SQL语句中的like和in查询的语法(C#)

    sql语句进行 like和in 参数化,按照正常的方式是无法实现的 我们一般的思维是: Like参数化查询:string sqlstmt = "select * from users whe ...

  6. Oracle中,利用sql语句中的函数实现保留两位小数和四舍五入保留两位小数

    Oracle中,利用sql语句中的函数实现保留两位小数和四舍五入保留两位小数: select trunc(1.23856789,2) from dual round(m,n) 可以四舍五入 trunc ...

  7. SQL Server 基础 04 函数与分组查询数据

    函数与分组查询数据 系统函数分 聚合函数.数据类型转换函数.日期函数.数学函数 . . . 1. 聚合函数 主要是对一组值进行计算,然后返回一个值. 聚合函数包括 sum(求和).avg(求平均值). ...

  8. 数据库 数据库SQL语句三

    转换函数 to_char()字符串转换日期函数 --查询大于某个日期的员工信息 select * from emp where hiredate>to_date('1980-02-12','yy ...

  9. mybatis的sql语句导致索引失效,使得查询超时

    mybaitis书写sql需要特别注意where条件中的语句,否则将会导致索引失效,使得查询总是超时.如下语句会出现导致索引失效的情况: with test1 as (select count(C_F ...

随机推荐

  1. rust漫游 - 写时拷贝 Cow<'_, B>

    rust漫游 - 写时拷贝 Cow<'_, B> Cow 是一个写时复制功能的智能指针,在数据需要修改或者所有权发生变化时使用,多用于读多写少的场景. pub enum Cow<'a ...

  2. ceph-csi源码分析(2)-组件启动参数分析

    更多ceph-csi其他源码分析,请查看下面这篇博文:kubernetes ceph-csi分析目录导航 ceph-csi源码分析(2)-组件启动参数分析 ceph-csi组件的源码分析分为五部分: ...

  3. 用户RFM模型及应用

    RMF含义 R(Recency)(用户粘性,越小越好):用户最近一次交易时间的间隔.R值越大,表示用户交易发生的日期越久,反之则表示用户交易发生的日期越近 F(Frequency)(用户忠诚度,越大越 ...

  4. 关于Excel中表格转Markdown格式的技巧

    背景介绍 Excel文件转Markdown格式的Table是经常会遇到的场景. Visual Studio Code插件 - Excel to Markdown table Excel to Mark ...

  5. Jquery手机点击其他地方隐藏控件问题

    因为不太懂mui的底部导航栏的操作,所以自己写了用很普通的方法实现手机底部导航栏,遇到了很多问题.比如:要实现点击底部菜单栏上某一个菜单,显示子菜单,然后点击手机空白处,隐藏菜单. 实现方法是: // ...

  6. 尝试用面向对象思维理解Vue组件

    什么是组件 用面向对象的思维去理解Vue组件,可以将所有的事物都抽象为对象,而类或者说是组件,都具有属性和操作. 如抽取人类为组件,其基本的属性有姓名.年龄.国籍:基本的方法有吃饭.睡觉.跑步等. & ...

  7. 用阻塞队列实现一个生产者消费者模型?synchronized和lock有什么区别?

    多线程当中的阻塞队列 主要实现类有 ArrayBlockingQueue是一个基于数组结构的有界阻塞队列,此队列按FIFO原则对元素进行排序 LinkedBlockingQueue是一个基于链表结构的 ...

  8. [转]12个scp传输文件的命令栗子

    原文地址: https://www.cnblogs.com/voidy/p/4215891.html copy原文是为了修改部分错误以及便于记录自己的笔记.英文原文点:这里 安全复制 Scp(Secu ...

  9. PHP经典算法之背包问题

    问题:假设有一个背包的负重最多可达8公斤,而希望在背包中装入负重范围内可得之总价物品,假设是水果好了,水果的编号.单价与重量如下所示: 1 栗子 4KG $4500 2 苹果 5KG $5700 3 ...

  10. Redis 高级面试题

    Redis 持久化机制 Redis 是一个支持持久化的内存数据库,通过持久化机制把内存中的数据同步到硬盘文件来 保证数据持久化.当 Redis 重启后通过把硬盘文件重新加载到内存,就能达到恢复数据的目 ...