没有合适的资源?快使用搜索试试~ 我知道了~
sql语句练习,帮助学习数据库的童鞋们,更好的掌握sql语句
资源推荐
资源详情
资源评论
今天在网上找了几道经典的 SQL 练习题做了一下,虽然都不难,但是对打基础是很有好处
的,在明白的基础上可以进一步做分析,来研究一下各种解法的优劣,甚至进行简单的优
化。
现在将题目和答案分享一下。我使用的是 MYSQL 5.0,但是绝大部分都是标准 SQL。
表结构:
CREATE TABLE STUDENT
(SNO VARCHAR(3) NOT NULL,
SNAME VARCHAR(4) NOT NULL,
SSEX VARCHAR(2) NOT NULL,
SBIRTHDAY DATETIME,
CLASS VARCHAR(5))
go
CREATE TABLE COURSE
(CNO VARCHAR(5) NOT NULL,
CNAME VARCHAR(10) NOT NULL,
TNO VARCHAR(10) NOT NULL)
go
CREATE TABLE SCORE
(SNO VARCHAR(3) NOT NULL,
CNO VARCHAR(5) NOT NULL,
DEGREE NUMERIC(10, 1) NOT NULL)
go
CREATE TABLE TEACHER
(TNO VARCHAR(3) NOT NULL,
TNAME VARCHAR(4) NOT NULL, TSEX VARCHAR(2) NOT NULL,
TBIRTHDAY DATETIME NOT NULL, PROF VARCHAR(6),
DEPART VARCHAR(10) NOT NULL)
INSERT INTO STUDENT (SNO,SNAME,SSEX,SBIRTHDAY,CLASS) VALUES (108 ,' 曾
华'
,'男' ,1977-09-01,95033);
INSERT INTO STUDENT (SNO,SNAME,SSEX,SBIRTHDAY,CLASS) VALUES (105 ,' 匡
明'
,'男' ,1975-10-02,95031);
INSERT INTO STUDENT (SNO,SNAME,SSEX,SBIRTHDAY,CLASS) VALUES (107 ,' 王
丽'
,'女' ,1976-01-23,95033);
INSERT INTO STUDENT (SNO,SNAME,SSEX,SBIRTHDAY,CLASS) VALUES (101 ,' 李
军'
,'男' ,1976-02-20,95033);
INSERT INTO STUDENT (SNO,SNAME,SSEX,SBIRTHDAY,CLASS) VALUES (109 ,' 王
芳'
,'女' ,1975-02-10,95031);
INSERT INTO STUDENT (SNO,SNAME,SSEX,SBIRTHDAY,CLASS) VALUES (103 ,' 陆
君'
,'男' ,1974-06-03,95031);
GO
INSERT INTO COURSE(CNO,CNAME,TNO)VALUES ('3-105' ,'计算机导论',825)
INSERT INTO COURSE(CNO,CNAME,TNO)VALUES ('3-245' ,'操作系统' ,804);
INSERT INTO COURSE(CNO,CNAME,TNO)VALUES ('6-166' ,'数据电路' ,856);
INSERT INTO COURSE(CNO,CNAME,TNO)VALUES ('9-888' ,'高等数学' ,100);
GO
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (103,'3-245',86);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (105,'3-245',75);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (109,'3-245',68);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (103,'3-105',92);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (105,'3-105',88);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (109,'3-105',76);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (101,'3-105',64);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (107,'3-105',91);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (108,'3-105',78);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (101,'6-166',85);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (107,'6-106',79);
INSERT INTO SCORE(SNO,CNO,DEGREE)VALUES (108,'6-166',81);
GO
INSERT INTO TEACHER(TNO,TNAME,TSEX,TBIRTHDAY,PROF,DEPART)
VALUES (804,'李诚','男','1958-12-02','副教授','计算机系');
INSERT INTO TEACHER(TNO,TNAME,TSEX,TBIRTHDAY,PROF,DEPART)
VALUES (856,'张旭','男','1969-03-12','讲师','电子工程系');
INSERT INTO TEACHER(TNO,TNAME,TSEX,TBIRTHDAY,PROF,DEPART)
VALUES (825,'王萍','女','1972-05-05','助教','计算机系');
INSERT INTO TEACHER(TNO,TNAME,TSEX,TBIRTHDAY,PROF,DEPART)
VALUES (831,'刘冰','女','1977-08-14','助教','电子工程系');
题目:
1、 查询 Student 表中的所有记录的 Sname、Ssex 和 Class 列。
2、 查询教师所有的单位即不重复的 Depart 列。
3、 查询 Student 表的所有记录。
4、 查询 Score 表中成绩在 60 到 80 之间的所有记录。
5、 查询 Score 表中成绩为 85,86 或 88 的记录。
6、 查询 Student 表中“95031”班或性别为“女”的同学记录。
7、 以 Class 降序查询 Student 表的所有记录。
8、 以 Cno 升序、Degree 降序查询 Score 表的所有记录。
9、 查询“95031”班的学生人数。
10、查询 Score 表中的最高分的学生学号和课程号。
11、查询‘3-105’号课程的平均分。
12、查询 Score 表中至少有 5 名学生选修的并以 3 开头的课程的平均分数。
13、查询最低分大于 70,最高分小于 90 的 Sno 列。
14、查询所有学生的 Sname、Cno 和 Degree 列。
15、查询所有学生的 Sno、Cname 和 Degree 列。
16、查询所有学生的 Sname、Cname 和 Degree 列。
17、查询“95033”班所选课程的平均分。
18、假设使用如下命令建立了一个 grade 表:
create table grade(low number(3,0),upp number(3),rank char(1));
insert into grade values(90,100,’A’);
insert into grade values(80,89,’B’);
insert into grade values(70,79,’C’);
insert into grade values(60,69,’D’);
insert into grade values(0,59,’E’);
commit;
现查询所有同学的 Sno、Cno 和 rank 列。
19、查询选修“3-105”课程的成绩高于“109”号同学成绩的所有同学的记录。
20、查询 score 中选学一门以上课程的同学中分数为非最高分成绩的记录。
21、查询成绩高于学号为“109”、课程号为“3-105”的成绩的所有记录。
22、查询和学号为 108 的同学同年出生的所有学生的 Sno、Sname 和 Sbirthday 列。
23、查询“张旭“教师任课的学生成绩。
24、查询选修某课程的同学人数多于 5 人的教师姓名。
25、查询 95033 班和 95031 班全体学生的记录。
26、查询存在有 85 分以上成绩的课程 Cno.
27、查询出“计算机系“教师所教课程的成绩表。
28、查询“计算机系”与“电子工程系“不同职称的教师的 Tname 和 Prof。
29、查询选修编号为“3-105“课程且成绩至少高于选修编号为“3-245”的同学的 Cno、Sno
和 Degree,并按 Degree 从高到低次序排序。
30、查询选修编号为“3-105”且成绩高于选修编号为“3-245”课程的同学的 Cno、Sno 和
Degree.
31、查询所有教师和同学的 name、sex 和 birthday.
32、查询所有“女”教师和“女”同学的 name、sex 和 birthday.
33、查询成绩比该课程平均成绩低的同学的成绩表。
34、查询所有任课教师的 Tname 和 Depart.
35 查询所有未讲课的教师的 Tname 和 Depart.
36、查询至少有 2 名男生的班号。
37、查询 Student 表中不姓“王”的同学记录。
38、查询 Student 表中每个学生的姓名和年龄。
39、查询 Student 表中最大和最小的 Sbirthday 日期值。
40、以班号和年龄从大到小的顺序查询 Student 表中的全部记录。
41、查询“男”教师及其所上的课程。
42、查询最高分同学的 Sno、Cno 和 Degree 列。
43、查询和“李军”同性别的所有同学的 Sname.
44、查询和“李军”同性别并同班的同学 Sname.
45、查询所有选修“计算机导论”课程的“男”同学的成绩表
参考答案:
1. SELECT SNAME,SSEX,CLASS FROM STUDENT;
剩余16页未读,继续阅读
资源评论
yiluxiangqianfengfan
- 粉丝: 0
- 资源: 9
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- HCIP-Datacom笔记 (1).pdf
- yolov5,SSD 可能使用到的一些代码
- bbbbbbbbbbbbbbbbbb
- 安卓逆向学习笔记之Frida Stalker 还原OLLVM AES.docx
- 安卓逆向学习笔记之unicorn来trace还原OLLVM Base64.docx
- 最新版本私钥助记词碰撞器大富豪使用python进行制作通过接口的方式进行验证支持多币种多链多网络一分钟万次验证高出货率
- 介绍离散性制造行业的MES系统流程
- Arduino IDE压缩包版本,2024年4月26日,最新版本
- 基于IDEA-CCNL/Randeng-Pegasus-238M-Summary-Chines微调的中文文本摘要任务源码+数据集
- 自动驾驶-状态估计和定位之直方图滤波(Histogram+Filter)定位应用和源码.pdf
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功