sql 的 count、avg

1、

sql 复制代码
"count:作用:计算,指定字段,在查询结构中出现的个数"

"查询结构都是 107,因为,employees表有107条记录"
SELECT 
	COUNT(employee_id), 
	COUNT(salary), 
	COUNT(2 * salary), 
	COUNT(1), 
	COUNT(2), 
	COUNT(*)
FROM employees

2、如何计算表中有多少条记录,如何实现?

sql 复制代码
问题:如何计算表中有多少条记录,如何实现?	
	方式一:count(*)
	方式二:count(0)、count(1)、count(3) ....
	方式三:count(具体字段x),这个方式不一定对,
		   因为计算的是:字段x为非null时候,如果字段x为null,就不会算上了

这三种方式,谁的效率高?
	如果使用的是MyISAM存储引擎,三者效率相同
	如果使用的是InnoDB存储引擎,则 count(*) = count(1) > count(具体字段x)

3、公式:avg = sum / count

需求:查询公司的平均奖金率

sql 复制代码
错误写法:
SELECT avg(commission_pct) 
FROM employees

正确写法:
SELECT 
	sum(commission_pct) / COUNT(IFNULL(commission_pct, 0)),
	avg(IFNULL(commission_pct, 0))
FROM employees

为什么 SELECT avg(commission_pct)错误写法

核心坑点:

MySQL 的 AVG() 函数会自动跳过 NULL 值!

  • 表中有 100 个员工
  • 其中 40 个有提成(commission_pct = 0.2/0.3...)
  • 60 个没有提成(commission_pct = NULL)

AVG(commission_pct) 计算时:

  1. 只算那 40 个有值的
  2. 分母是 40,不是 100
  3. 结果 = 40人总提成 / 40人
    这不是公司全员平均提成,只是"有提成的人的平均"
    业务逻辑错误!

正确写法:完美解决 NULL 问题

sql 复制代码
-- 写法1
sum(commission_pct) / COUNT(IFNULL(commission_pct, 0))

-- 写法2
avg(IFNULL(commission_pct, 0))

原理:

IFNULL(commission_pct, 0)

→ 把所有 NULL 变成 0

→ 分母变成 总人数(100人)

→ 结果 = 公司全员平均提成


一句话总结(必背)

  1. AVG(字段)不算 NULL,只算有值的行(坑!)
  2. AVG( IFNULL(字段, 0) )NULL 当 0 算,算全部行(对!)

最终结论

你已经精准抓住了 AVG 函数处理 NULL 的核心陷阱

  • 错误写法:漏算 NULL,结果偏大 ❌
  • 正确写法:NULL 转 0,全员平均 ✅
相关推荐
zzzzzz3101 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
云技纵横3 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
BD_Marathon5 天前
SQL学习指南——视图
数据库·sql
2601_962072555 天前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
HackTwoHub5 天前
Sqli-Scanner SQL注入SKILL自动化挖掘SQL注入,零依赖自动化SQL注入挖掘,赏金猎人
数据库·人工智能·sql·web安全·网络安全·自动化·系统安全
Volunteer Technology5 天前
Flink Table API与SQL(一)
大数据·sql·flink
持敬chijing5 天前
Web渗透之SQL注入-常用sql语句
sql·安全·web安全·网络安全
Theo·Chan5 天前
更换 Kingbase V9 License 踩坑记
sql·信创·kingbase
yangshicong5 天前
第16章:AI数据分析与Text-to-SQL
人工智能·python·sql·数据分析·langchain
Chengbei115 天前
AISec真正拟人化全自动渗透工具!支持浏览器交互全自动化挖掘,SQL注入、XSS、越权等。
sql·安全·web安全·网络安全·自动化·系统安全·xss