SQL零基础入门教程,贼拉详细!贼拉简单! 速通数据库期末考!(十)

SQL 函数

SQL 拥有很多可用于计数和计算的内建函数。 比如:

AVG() - 返回平均值

COUNT() - 返回行数

MAX() - 返回最大值

MIN() - 返回最小值

SUM() - 返回总和

FIRST() - 返回第一个记录的值

LAST() - 返回最后一个记录的值

GROUP BY

学习SQL函数前,先学习 GROUP BY 命令,因为 GROUP BY 经常与聚合函数一起使用,根据一个或多个列对结果集进行分组(将相同的字段值分为一组)

语法:

sql 复制代码
SELECT columns
FROM table_name
GROUP BY column_name;

columns: 要查询的列名
table_name:表名
column_name:用于分组操作的字段名,可以为多个

示例:

查询全校所有班级

sql 复制代码
SELECT clazz AS 班级
FROM students
GROUP BY clazz;

查询所有班级及各班级学生的年龄分组

sql 复制代码
SELECT clazz AS 班级,age AS 年龄
FROM students
GROUP BY clazz,age;

AVG()平均值函数

AVG() 函数返回数值列的平均值

语法:

sql 复制代码
SELECT AVG(column_name) FROM table_name

column_name:字段名(必须是数值字段)
table_name:表名

示例:

查询各班级所有学生的平均年龄,并按平均年龄升序排列:

sql 复制代码
SELECT clazz AS 班级,AVG(age) AS 平均年龄
FROM students
GROUP BY clazz
ORDER BY AVG(age);

关联学生数据表和学生成绩表,查询每位学生的平均成绩,并按平均成绩降序排列:

sql 复制代码
SELECT a.id AS 学生ID,
			 name AS 姓名,
			 AVG(score) AS 平均成绩,
			 clazz AS 班级
FROM score AS a
INNER JOIN students AS b
ON a.id = b.id
GROUP BY a.id
ORDER BY 平均成绩 DESC;

本专栏将持续更新,对数据库SQL感兴趣的同学可以关注一下,谢谢!

相关推荐
05候补工程师5 分钟前
【英语学习笔记】基于“底层逻辑转换”与“去动词化”的英汉互译核心方法论及写作高分公式
经验分享·笔记·学习·考研
weixin_468466858 分钟前
Airtable 零基础快速上手与实战指南
数据库·人工智能·python·深度学习·ai·大模型
凯瑟琳.奥古斯特9 分钟前
10道数据库原理精选题
开发语言·数据库·职场和发展·数据库开发
大明者省23 分钟前
CentOS 与 Ubuntu Python 部署差异
笔记·python·ubuntu·centos
Rick199324 分钟前
Redis 高频面试 10 题
数据库·redis·面试
bbaydnog28 分钟前
FreeRTOS学习笔记 17:资源管理与临界区保护——优先级反转、死锁,90%的RTOS bug都跟它有关
笔记·学习·bug
fanged28 分钟前
Datasheet学习5(STM32)(TODO)
笔记
陈橘又青35 分钟前
国产数据库工具测评:DBLens 以本地化工程能力与 AI 演进路径凸显优势
数据库
念恒1230635 分钟前
MySQL事务(下)---MySQL InnoDB MVCC 与 Read View:从隐藏列、Undo Log 到 RR 与 RC 的本质区别
数据库·mysql·oracle
i220818 Faiz Ul35 分钟前
在线预约导游|基于SSM+vue的在线预约导游系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·在线预约导游系统