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

查询格式总结

相关推荐
星星点点洲3 分钟前
【缓存与数据库结合方案】伪从技术 vs 直接同步/MQ方案的深度对比
数据库·缓存
努力奋斗的小杨6 分钟前
学习MySQL的第十二天
数据库·笔记·学习·mysql·navicat
枫叶20001 小时前
OceanBase数据库-学习笔记1-概论
数据库·笔记·学习·oceanbase
仲夏plus1 小时前
MySQL:慢SQL索引优化-使用explain/analyze进行耗时分析的方法
数据库
tcoding1 小时前
《MySQL 技术内幕-innoDB 存储引擎》笔记
数据库·笔记·mysql
Edward.W2 小时前
如何有效防止 SQL 注入攻击?
数据库·sql
好想有猫猫2 小时前
【Redis】服务端高并发分布式结构演进之路
数据库·c++·redis·分布式·缓存
桥Dopey3 小时前
关系型数据库PostgreSQL for Mac 保姆级使用教程
数据库·postgresql
@_猿来如此3 小时前
Django 实现电影推荐系统:从搭建到功能完善(附源码)
数据库·后端·python·django
nbsaas-boot3 小时前
SQL Server 存储过程开发手册
数据库