数据库实验【5】 | 单表查询

[例3.18] 査询全体学生的详细记录

SELECT Sno,Sname,Ssex,Sage,Sdept
FROM Student;
--或
SELECT *
FROM Student;

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

SELECT Sname,2014-Sage /*假设当时为2014年*/
FROM Student;

在这里插入图片描述

[例3.20] 查询全体学生的姓名、出生年份和所在的院系,要
求用小写字母表示系名。

小写是LOWER,大写是UPPER

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;

在这里插入图片描述
[例3.21] 查询选修了课程的学生学号。

SELECT Sno FROM SC;
--等价于
SELECT ALL Sno FROM SC;

若要删除重复行:

select distinct Sno From SC;

在这里插入图片描述
[例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;

结果为空
在这里插入图片描述
[例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;

在这里插入图片描述
[例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 ('IS','MA’,'CS' );

在这里插入图片描述
[例3.29]查询学号为201215121的学生的详细情况

SELECT*
FROM Student
WHERE Sno LIKE'201215121';
等价于
SELECT*
FROM Student
WHERE Sno='201215121';

在这里插入图片描述

LIKE后若没有通配符,则可以用‘=’取代,同理可用’!=’ '<>'代替NOT LIKE

[例3.30]查询所有姓刘的学生的姓名、学号和性别

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

在这里插入图片描述

[例3.31]查询姓“欧阳”且全名为三个汉字的学生的姓名

SELECT Sname 
FROM Student
WHERE Sname LIKE '欧阳_';

在这里插入图片描述

[例3.32]查询名字中第二个字为“阳”的学生的姓名和学号

SELECT Sname 
FROM Student
WHERE Sname LIKE '_阳%';

在这里插入图片描述

[例3.33]查询所有不姓刘的学生的姓名、学号和性别

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

在这里插入图片描述
[例3.34]查询DB_Design课程的课程号和学分
如果用户要查询的字符串本身就含有通配符%或_,这时就要使用ESCAOE‘<换码字符>’短语对通配符进行定义了

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

在这里插入图片描述

[例3.35]查询以“DB_”开头,且倒数第三个字符为i的课程的详细情况

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

在这里插入图片描述

[例3.36]某些学生选修课程后没有参加考试,所以有选课记录,但没有考试成绩,查询缺少考试成绩的学生的学号和相应的课程号

SELECT Sno,Cno
FROM SC
WHERE Grade IS NULL

在这里插入图片描述

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

SELECT Sno , Cno FROM SC WHERE Grade is not null;
SELECT Sno , Cno FROM SC WHERE Grade != null;

在这里插入图片描述
[例3.38] 查询计算机科学系年龄在20岁以下的学生姓名

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

在这里插入图片描述
[例3.39] 査询选修了 3号课程的学生的学号及其成绩,査询结果按分数的降序排列

select Sno , Grade
from SC where Cno = '3' 
order by Grade desc;

在这里插入图片描述

对于 NULL 空值的处理 在降序时被排在了最后,升序时候是在最前面的:
select Sno , Grade
from SC where Cno = '3' 
order by Grade asc;

在这里插入图片描述

[例3.40] 査询全体学生情况,査询结果按所在系的系号升序排列,同一系中的学生按年龄降序排列

select * 
from Student 
order by Sdept asc, Sage desc;

在这里插入图片描述
[例3.41] 査询学生总人数

select count(*) 
from Student;

在这里插入图片描述

[例3.42] 査询选修了课程的学生人数

select count(distinct Sno)
from Student;

在这里插入图片描述
同理,我们可以查询课程一共有几个,代码如下:

select count(distinct Cno) from Course;

在这里插入图片描述
[例3.43] 计算选修1号课程的学生平均成绩

select avg(Grade) 
from SC where Cno = '1';

在这里插入图片描述
[例3.44] 査询选修1号课程的学生最高分数

select max(Grade) 
from SC where Cno = '1';

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

select sum(Ccredit) 
from SC,Course 
where Sno = '201215126' and SC.Cno = Course.Cno;

在这里插入图片描述
[例3.46] 求各个课程号及相应的选课人数。

select Cno , Count(Sno) 
from SC group by Cno;

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

select Sno 
from SC
group by Sno having count(*) > 3;

在这里插入图片描述
没有结果时候,不会输出任何值。

[例3.48]查询平均成绩大于等于90的学生学号和平均成绩

select Snoopy,AVG(Grade)
from SC
GROUP BY Sno
HAVING AVG(Grade)>=90

在这里插入图片描述

这次例题很多,慢慢消化

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值