05_MySQL常见函数_分组函数
# 分组函数
/*
功能: 统计,又称为聚合函数,统计函数,组函数
传入一组值,统计后得到一个值
分类:
sum 求和,avg 平均值,max 最大值,min 最小值,count 计算个数
特点:
1. sum,avg处理数值型
max,min,count处理任何类型
2. 是否忽略null值
分组函数都忽略null值,不参与统计
3. 可以和distinct搭配,先去重再计算
4、count函数的详细介绍
count(x) x字段的非null行数
count(*) 表的总行数(一行中只要有1个字段不为null, 则计入)
count(常量) 表的总行数(相当于表中增加1列,值为给定的常量
统计效率:
存储引擎为myisam, count(*)效率最好,有1个内部计数器直接保存了count(*)
存储引擎为innodb, count(*)和count(1)类似,但比count('常量字段')效率高(要判断null)
5、和分组函数一同查询的字段有限制(返回的逻辑表,结构要规则)
要求是group by后的字段(逻辑表要规则)
*/
# 1、简单的使用
SELECT SUM(salary) FROM employees;
SELECT AVG(salary) FROM employees;
SELECT MAX(salary) FROM employees;
SELECT MIN(salary) FROM employees;
SELECT COUNT(salary) FROM employees;
SELECT SUM(salary) AS 和, TRUNCATE(AVG(salary),4) 平均, MAX(salary) 最大
FROM employees;
# 2、参数支持哪些类型
# sum,avg: 数值类型才有意义
# max,min: 数值类型,字符型(字典顺序), 日期型
# count: 数值,字符,日期型(非null的个数)
SELECT MAX(hiredate),MIN(hiredate) FROM employees;
SELECT COUNT(last_name), COUNT(commission_pct) FROM employees; # 107,35
# 3、是否忽略null值
# 忽略null值
SELECT SUM(commission_pct), AVG(commission_pct)FROM employees;
# 忽略null值
SELECT MAX(commission_pct), MIN(commission_pct) FROM employees;
# 4、和distinct搭配(去重统计)
SELECT SUM(DISTINCT salary), SUM(salary) FROM employees; # 先去重再求和
SELECT COUNT(DISTINCT salary), COUNT(salary) FROM employees; # 先去重再计数
SELECT MAX(DISTINCT salary), MIN(DISTINCT salary) FROM employees; # 先去重
# 5、count的详细介绍
SELECT COUNT(salary) FROM employees; # salary字段的非null行数
SELECT COUNT(*) FROM employees; # count(*),表的总行数(一行中只要有1个字段不为null, 则计入)
SELECT COUNT(1) FROM employees; # 等价于给表增加了1列1, 统计该列的行数(表的实际行数)
# 6、和分组函数一同查询的字段有限制
# 逻辑表的结构也要规则(不能1个字段x行,1个字段y行)
# 错误实例
SELECT AVG(salary), employee_id FROM employees; # avg只有1行,employee_id有107行,结果肯定有问题
05_MySQL常见函数_分组函数的更多相关文章
- 04_MySQL常见函数_单行函数
#单行函数细分1.字符函数2.数学函数3.日期函数4.其他函数5.流程控制函数 #单行函数 - 字符函数#一.字符函数#1. length 获取参数的字节长度SELECT LENGTH('john') ...
- mysql基础教程(二)-----分组函数、多表查询、常见函数
分组函数 什么是分组函数 分组函数作用于一组数据,并对一组数据返回一个值. 组函数类型 • AVG() • COUNT() • MAX() • MIN() • SUM() 组函数语法 AVG(平均值) ...
- mysql 字符串函数、分组函数
字符串函数 1.concat 函数 drop table test;create table test(id int(4), name varchar(10), sex char(2));insert ...
- DQL---条件查询、单行函数、多行函数、分组函数、数据类型
一.DQL 1.基本规则: (1)对于日期型数据,做 *,/ 运算不合法,可以进行 +, - 运算.比如给日期加一天或减一个月,结果仍为一个日期.两个日期间只能为减法,返回两个日期相差的天数,两个日期 ...
- (四)MySQL条件查询(通配符、模糊查询)、排序查询、分组查询(单行、分组函数)
一.条件查询 1.含义:前面学的基础查询可以查询一个或多个字段,如果需要的数据仅仅是其中的某一行或多行就用到了条件查询. 2.语法:(序号表示语句执行顺序) SELECT 字段名 ③ FROM 表名 ...
- oracle(sql)基础篇系列(一)——基础select语句、常用sql函数、组函数、分组函数
花点时间整理下sql基础,温故而知新.文章的demo来自oracle自带的dept,emp,salgrade三张表.解锁scott用户,使用scott用户登录就可以看到自带的表. #使用ora ...
- Oracle_SQL函数-分组函数
分组函数 什么是分组函数 分组函数作用于一组数据,并对一组数据返回一个值 组函数类型:主要有6种 AVG - 平均 COUNT - 计数 MAX - 最大 MIN - 最小 SUM - 求和 STDD ...
- oracle 10g 学习之多表查询、分组函数(6)
笛卡尔集 l 笛卡尔集会在下面条件下产生: 省略连接条件 连接条件无效 所有表中的所有行互相连接 l 为了避免笛卡尔集, 可以在 WHERE 加入有效的连接条件. 自连接 select m.las ...
- 常用分组函数count-avg-sum-max-min
分组函数也称多行函数,用于对一组数据进行运算,针对一组数据(取自于多行记录的相同字段)只返回一个结果,例如计算公司全体员工的工资总和.最高工资.最低工资.各部门的员工平均工资(按部门分组)等.由于分组 ...
随机推荐
- RESTful API 设计最佳实践【转】
背景 目前互联网上充斥着大量的关于RESTful API(为了方便,后面API和RESTful API 一个意思)如何设计的文章,然而却没有一个“万能”的设计标准:如何鉴权?API格式如何?你的API ...
- Android集成百度地图SDK
本Demo中所含功能 1:定位,显示当前位置 2:地图多覆盖物(地图描点.弹出该点的具体信息) 3:坐标地址互相换算 4:POI兴趣点检索 5:线路查询(步行,驾车,公交) 6:绘制线路(OpenGL ...
- nodejs与c语言交互应用实例
nodejs与c/c++交互目前主流的方式有两种,node addon c++ 和 node-ffi . 1.node addon c++ 1)nodejs从c语言读取数据 addon.c #incl ...
- 从原型链看DOM--Comment,CDATASection,DocumentType,DocumentFragment,Attr类型
这次总结的是剩下的这些DOM类型节点,可能你见过却不经常使用但是了解一下总是好的,可以加深对DOM体系的整体理解~.本篇要介绍的是Comment,CDATASection,DocumentType,D ...
- Spring第一弹—-全面阐述Spring及轻重量级容器的划分
Spring是什么? Spring是一个开源的控制反转(Inversion of Control ,IoC)和面向切面(AOP)的容器框架,它的主要目得是简化企业开发. IOC 控制反转 : 1 ...
- Java栈之链式栈存储结构实现
一.链栈 采用单链表来保存栈中所有元素,这种链式结构的栈称为链栈. 二.栈的链式存储结构实现 package com.ietree.basic.datastructure.stack; /** * 链 ...
- 关于Softnet的加密。方式是使用API函数。。关键是开发号
首先是获取 开发号. 类似于这个玩意 http://www.cnblogs.com/wenluderen/p/4853563.html 这个帖子里面有介绍关于开发号的完整资料. ××××××××××× ...
- Python函数参数*args和**kwargs
1. Python中使用*args和**kwargs #!/usr/bin/env python3 # coding: utf-8 # File: args_kwargs_demo.py # Auth ...
- C# 将 HTML 转换为图片或 PDF
首先是把 HTML 转换为图片. public partial class Form1 : Form { public Form1() { InitializeComponent(); } WebBr ...
- asp.net时间显示
DateTime dt = DateTime.Now;// Label1.Text = dt.ToString();//2005-11-5 13:21:25// Label2.Text = ...