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

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

数据库作业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.csdn.net/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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值