数据库作业5:查询、排序、聚集函数

本文介绍了SQL中的基本查询操作,包括选择计算后的值、消除重复行、使用ORDER BY进行排序、运用聚集函数如COUNT、AVG、MAX等,并探讨了如何处理NULL值,以及GROUP BY语句在分组查询中的应用。通过多个实例展示了如何在数据库中进行高效的数据检索和分析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据库作业5:查询、排序、聚集函数

一、单表查询

1、查询经过计算的值

[例3.19]查询全体学生的姓名及其出生年份。

SELECT Sname,2014-Sage
FROM Student;

在这里插入图片描述
此处查询最后显示无列名,尝试后发现加上’2014-Sage’即可显示列名!!
在这里插入图片描述
[例3.20]查询全体学生的姓名、出生年份和所在院系,要求用小写字母表示系名

SELECT Sname,'Year of Birth:',2014-Sage,LOWER(Sdept)
FROM Student;

在这里插入图片描述

SELECT Sname NAME,'Year of Birth:' BIRTH,2014-Sage BIRTHDAY,
	LOWER(Sdept) DEPARTMENT
FROM Student;

在这里插入图片描述
那么,如何将系名大写呢??
查找资料后得知使用UPPER()函数即可,参考博客链接:https://blog.youkuaiyun.com/zisongjia/article/details/52597206

SELECT Sname NAME,'Year of Birth:' BIRTH,2014-Sage BIRTHDAY,
	UPPER(Sdept) DEPARTMENT
FROM Student;

在这里插入图片描述
大写转换成功!!!

2、选择表中的若干元组

1)消除取值重复的行

通过DISTINCT可将元组投影后的相同行去掉。

[例3.21]查询选修了课程的学生学号

SELECT Sno
FROM SC;--选修了课程的学生学号

在这里插入图片描述
在该表中出现了许多重复的行,可以使用DISTINCT去重!!!

SELECT DISTINCT Sno
FROM SC;

在这里插入图片描述

2)查询满足条件的元组

[例3.22]查询计算机科学系全体学生的名单

SELECT Sname
FROM Student
WHERE Sdept='CS';

在这里插入图片描述
[例3.23]查询所有年龄在20岁以下的学生姓名及其年龄

SELECT Sname,Sage
FROM Student
WHERE Sage<20;

在这里插入图片描述
[例3.24]查询考试成绩不及格的学生的学号

SELECT DISTINCT Sno
FROM SC
WHERE Grade<60;

此时不及格的同学不需要重复查询,需要去重!
在这里插入图片描述
查询没有结果??
打开表之后发现没有不及格同学
在这里插入图片描述
BETWEEN…AND…和NOT BETWEEN…AND…可以用来查找属性值在指定范围内的元组,BETWEEN后是范围的下限,AND后是范围的上限。

[例3.25]查询年龄在20~23岁(包括20岁和23岁)之间的学生的姓名、系别和年龄

SELECT Sname,Sdept,Sage
FROM Student
WHERE Sage BETWEEN 20 AND 23

在这里插入图片描述
[例3.26]查询年龄不在20~23岁之间的学生姓名、系别和年龄。

SELECT Sname,Sdept,Sage
FROM Student
WHERE Sage NOT BETWEEN 20 AND 23;

在这里插入图片描述
谓词IN可以用来查找属性值属于指定集合的元组

[例3.27]查询计算机科学系(CS)、数学系(MA)和信息系(IS)学生的姓名和性别

SELECT Sname,Ssex
FROM Student
WHERE Sdept IN('CS','MA','IS');

在这里插入图片描述
[例3.28]查询既不是计算机科学系、数学系,也不是信息系的学生的姓名和性别。

SELECT Sname,Ssex
FROM Student
WHERE Sdept NOT IN('CS','MA','IS');

3)通配符%和_的测试

为了测试建立Text0表;

CREATE TABLE Text0(--测试用表
	Text1 CHAR(20),
	Sname CHAR(9),
);

在这里插入图片描述
将数据加入Text0表(为了测试方便,名字字母随便起的^ ^);

INSERT INTO Text0(Text1,Sname) VALUES('acb','李勇');
INSERT INTO Text0(Text1,Sname) VALUES('addgb','欧阳啊');
INSERT INTO Text0(Text1,Sname) VALUES('ab','欧阳这');
INSERT INTO Text0(Text1,Sname) VALUES('afb','啊欧阳');
INSERT INTO Text0(Text1,Sname) VALUES('qada','不是欧阳');

a%b;

SELECT DISTINCT Text1,Sname
FROM Text0
WHERE TEXT1 LIKE 'a%b';

在这里插入图片描述
a_b;
在这里插入图片描述
a____b;
在这里插入图片描述
欧阳_;
在这里插入图片描述
数据库字符集为ASCII时一个汉字需要两个_;当字符集为GBK时只需要一个_。

__欧阳;
在这里插入图片描述
测试完毕!好耶!

[例3.29]查询学号为201215121的学生的详细情况。

SELECT*
FROM Student
WHERE Sno LIKE '201215121';

在这里插入图片描述
在此处,LIKE与=等效,如下:
在这里插入图片描述
[例3.30]查询所有姓刘的学生的姓名、学号和性别。

SELECT Sname,Sno,Ssex
FROM Student
WHERE Sname LIKE '刘%';

在这里插入图片描述
[例3.31]查询姓“欧阳”且全名为三个汉字的学生的姓名。

书中Student表中无欧阳,因此用创建的测试表Text0;

SELECT Sname
FROM Text0
WHERE Sname LIKE '欧阳_'

在这里插入图片描述
[例3.32]查询名字中第二个字为“阳”的学生的姓名和学号。

SELECT Sname
FROM Text0
WHERE Sname LIKE '_阳%'

在这里插入图片描述
[例3.33]查询所有不姓刘的学生的姓名、学号和性别。

SELECT Sname,Sno
FROM Student
WHERE Sname NOT LIKE '刘%'

在这里插入图片描述
[例3.34]查询DB_Design课程的课程号和学分

SELECT Cno,Ccredit
FROM Course
WHERE Cname LIKE 'DB\_Design'ESCAPE '\';

在这里插入图片描述
[例3.35]查询以“DB_”开头且倒数第三个字符为i的课程的详细情况
Course表中填入数据
在这里插入图片描述

SELECT*
FROM Course
WHERE Cname LIKE 'DB\_%i__'ESCAPE '\';

在这里插入图片描述
[例3.36]某些学生选修课程没有参加考试,所以有选课记录,没有考试成绩,查询缺少成绩的学生学号和相应的课程号。

SELECT Sno,Cno
FROM SC
WHERE Grade IS NULL;

在这里插入图片描述
尝试IS用=代替
在这里插入图片描述
查询没有报错!!但是没有结果!

查询资料之后得知:

在SQL中,NULL是一种特有的数据类型,其等价于没有任何值、是未知数。NULL与0、空字符串、空格都不同。SQL默认情况下对WHERE XX!= Null的判断会永远返回0行,却不会提示语法错误。
非ANSI SQL标准中data=NULL等同于data IS NULL,data<>NULL等同于data IS NOT NULL。
所以:默认情况下做比较条件时使用关键字“is null”和“is not null”。

参考资料链接:https://zhidao.baidu.com/question/334249200.html

[例3.37]查询所有有成绩的学生学号和课程号

SELECT Sno,Cno
FROM SC
WHERE Grade IS NOT NULL;

在这里插入图片描述
此处!=同理:
在这里插入图片描述

[例3.38]查询计算机科学系年龄在20岁一下的学生姓名。

SELECT Sname
FROM Student
WHERE Sdept='CS' AND Sage<20;

在这里插入图片描述
可以用OR运算符写成如下等价形式:

SELECT Sname,Ssex
FROM Student
WHERE Sdept='CS' OR Sdept='MA' OR Sdept='IS';

在这里插入图片描述

3、ORDER BY子句

用户可以用ORDER BY子句对查询结果按照一个或多个属性列的升序(ASC)或降序(DESC)排序,默认值为升序。

[例3.39]查询选了3号课程的学生的学号及其成绩,查询的结果按分数的降序排列。

SELECT Sno,Grade
FROM SC
WHERE Cno='3'
ORDER BY Grade DESC;

在这里插入图片描述
[例3.40]查询全体学生清空,查询结果按所在系的系号升序排列,同一系中的学生按年龄降序排列。

SELECT*
FROM Student
ORDER BY Sdept,Sage DESC;

在这里插入图片描述

4、聚集函数

COUNT * --统计元组个数
COUNT([DISTINCT|ALL]<列名>) --统计一列中值的个数
SUM([DISTINCT|ALL]<列名>)  --计算一列值的总和(此列必须时数值型)
AVG([DISTINCT|ALL]<列名>)  --计算一列值的平均值(此列必须是数值型)
MAX([DISTINCT|ALL]<列名>)  --求一列值的最大值
MIN([DISTINCT|ALL]<列名>)  --求一列值的最小值

[例3.41]查询学生总人数

SELECT COUNT(*)
FROM Student;

在这里插入图片描述
[例3.42]查询选修了课程的学生人数

SELECT COUNT(DISTINCT Sno)
FROM SC;

在这里插入图片描述
为避免重复计算学生人数,必须在COUNT函数中用DISTINCT短语

[3.43]计算选修1号课程的学生平均成绩

SELECT AVG(Grade)AVG1
FROM SC
WHERE Cno='1';

在这里插入图片描述
此时可以加上AVG1为列名:
在这里插入图片描述

[例3.44]查询选秀1号课程的学生最高分数。

SELECT MAX(Grade)MAX
FROM SC
WHERE Cno='1';

在这里插入图片描述
[例3.45]查询学生201215012选修课程的总学分数

SELECT SUM(Ccredit)
FROM SC,Course
WHERE Sno='201215012' AND SC.Cno=Course.Cno;

在这里插入图片描述

5、GROUP BY语句

GROUP BY子句将查询结果按某一列或多列的值分组,值相等的为一组。

[3.46]求各个课程号及相应的选课人数

SELECT Cno,COUNT(Sno)
FROM SC
GROUP BY Cno;

在这里插入图片描述
[3.47]查询选修了三门以上课程的学生学号

SELECT Sno
FROM SC
GROUP BY Sno
HAVING COUNT(*)>3

在这里插入图片描述
没有人选秀三门以上课程,因此降低数据再次测试!!

SELECT Sno
FROM SC
GROUP BY Sno
HAVING COUNT(*)>3

在这里插入图片描述
测试成功!好耶!

至此,查询、排序、聚集函数中例3.19~例3.47已全部实现!!

感谢阅读!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值