SQL单表查询(2)

对查询结果排序

◆使用ORDER BY子句
-- 可以按一个或多个属性列排序
-- 升序:ASC;降序:DESC;缺省值为升序
◆ 当排序列含空值时
-- ASC:排序列为空值的元组最后显示
-- DESC:排序列为空值的元组最先显示
eg**:** 查询全体学生情况,查询结果按所在系的系号升序排列,同一系中的学生按年龄降序排列

sql 复制代码
SELECT *
FROM Student
ORDER BY Sdept,Sage DESC;

Sdept为主排序,Sage为次要排序,当系相同才按年龄排序。

使用集函数

5 类主要集函数
-- 统计个数
COUNT < 列名 >
-- 计算列总和
SUM < 列名 >
-- 计算列平均值
AVG < 列名 >
-- 求列最大值
MAX < 列名 >
-- 求列最小值
MIN < 列名 >
eg: 查询选修了课程的学生人数

sql 复制代码
SELECT COUNT(DISTINCT Sno)
FROM SC;

注: DISTINCT 以避免重复计算学生人数

对查询结果分组

用途
-- 细化集函数的作用对象
• 未对查询结果分组,集函数将作用于整个查询结果
• 对查询结果分组后,集函数将分别作用于每个组
◆使用GROUP BY子句分组
-- 分组方法:按指定的一列或多列值分组,值相等的为一组
-- 使用GROUP BY子句后,SELECT子句的列名列表中只能出现分组属性和集函数
eg: 求各个课程号及相应的选课人数

sql 复制代码
SELECT Cno,COUNT(Sno)
FROM SC
GROUP BY Cno

◆ 使用HAVING短语筛选最终输出结果
-- 只有满足HAVING短语指定条件的组才输出
◆ HAVING短语与WHERE子句的区别:作用对象不同
-- WHERE子句作用于基表或视图,从中选择满足条件的元组
-- HAVING短语作用于组,从中选择满足条件的组
eg: 查询选修了 3 门以上课程的学生学号

sql 复制代码
SELECT Sno
FROM SC
GROUP BY Sno
HAVING COUNT(*) >=3

查询格式总结

相关推荐
Absurd58715 小时前
JavaScript中模块化在游戏引擎开发中的资源调度作用
jvm·数据库·python
2301_8152795216 小时前
SQL如何利用聚合函数生成业务分析指标_KPI计算基础教程
jvm·数据库·python
qq_3300379916 小时前
mysql如何排查Out of memory错误_mysql内存分配调优
jvm·数据库·python
weixin_4585801217 小时前
如何在 Go 中直接将 AST 编译为可执行二进制文件?
jvm·数据库·python
Highcharts.js19 小时前
Highcharts Grid 中文站正式上线:表格数据处理的全新选择
前端·javascript·数据库·表格数据·highcharts·可视化图表·企业级图表
Elastic 中国社区官方博客1 天前
Elasticsearch:使用 Agent Builder 的 A2A 实现 - 开发者的圣诞颂歌
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
2301_816660211 天前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
qq_372154231 天前
Go 中自定义类型与基础类型的显式转换规则详解
jvm·数据库·python
_下雨天.1 天前
NoSQL之Redis配置与优化
数据库·redis·nosql
LiAo_1996_Y1 天前
CSS如何实现文字渐变效果_通过background-clip实现艺术字
jvm·数据库·python