




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上sql语句练习题1数据库有如下四个表格:student(sno,sname,sage,ssex,sdpt) 学生表系表(dptno,dname)course(cno,cname, gradet, tno) 课程表sc(sno,cno,score) 成绩表teacher(tno,tname) 教师表 要求:完成以下操作1. 查询姓"欧阳"且全名为三个汉字的学生的姓名。select sname from student where sname like “欧阳_;2. 查询名字中第
2、2个字为"阳"字的学生的姓名和学号。 select sname,sno from student where sname like '_阳%';3. 查询所有不姓刘的学生姓名。select sname,sno,ssex from student where sname not like “刘%”;4. 查询db_design课程的课程号和学分。 select cno,ccred
3、it from course where cname like 'db_design' 5. 查询以"db_"开头,且倒数第3个字符为i的课程的详细情况。 select * from course where cname like 'db%i_ _';6. 某些学生选修课程后没有参加考试,所以有选课记录,但没有考试成绩。查询缺少成绩的学生的学号和相应的课程号。select sno,c
4、no from sc where grade is null;7. 查所有有成绩的学生学号和课程号。select sno,cno from sc where grade is not null;8. 查询计算机系年龄在20岁以下的学生姓名。 select sname from student where sdept= 'cs' and sage<
5、;20;9. 查询选修了3号课程的学生的学号及其成绩,查询结果按分数降序排列。 select sno,grade from sc where cno= ' 3 ' order by grade desc;10. 查询学生总人数。select count(*) from student;11. 查询选修了课程的学生人数。select count(distinct sno) from
6、0;sc;12. 计算1号课程的学生平均成绩。select avg(grade) from sc where cno= ' 1 ';13. 查询选修1号课程的学生最高分数。select max(grade) from sc where cno= ' 1 ';14. 查询学生选修课程的总学分数。select sum(grade) from sc,course wh
7、ere sno= ' ' and o=o;15. 查询选修了3门以上课程的学生学号。select sno from sc group by sno having count(*) >3; 16. 查询每个学生及其选修课程的情况。select student.*,sc.*, course.* from student,sc , course where student.sno=sc.sno and o=o;17. 查询每
8、个学生及其选修课程的情况包括没有选修课程的学生18. 查询选修2号课程且成绩在90分以上的所有学生的学号、姓名select student.sno, student.snamefrom student,scwhere student.sno=sc.sno and o=”2and sc.grade>90;19. 查询每个学生的学号、姓名、选修的课程名及成绩。select student.sno,sname,ssex,sage,sdept,cno,gradefrom student left outjoin sco on(student.sno=sc.sno);20. 查询与“刘晨”在同一个
9、系学习的学生。selectsno,sname,sdeptfrom studentwhere sdept in(select sdept from student where sname=”刘晨);21. 查询选修了课程名为“信息系统”的学生学号和姓名select sno,sname from student where sno in(select sno from sc where cno in (select cno from course where cname=”信息系统);22. 找出每个学生超过他选修课程平均成绩的课程号。select sno,cno from sc x where
10、grade>=(select avg(grade) from sc y where y.sno=x.sno);23. 将一个新学生记录(学号:;姓名:陈冬;性别:男;所在系:is;年龄:18岁)插入到student表中。insert into student values ('','陈冬','男','is',18);24. 将学生的年龄改为22岁。update student setsage=22 where sno='';25. 将所有学生的年龄增加1岁。update student setsage=sag
11、e+1;26. 将计算机科学系全体学生的成绩置零。update sc set grade=0 where exits(selete * from student where student.sno=sc.sno and sdept=” 计算机科学系”);27. 删除学号为的学生记录delete from student where sno=”';28. 删除所有的学生选课记录。delete from sc;29. 删除2号课程的所有选课记录。delete from sc where cno='2';30. 删除计算机科学系所有学生的选课记录。delete from sc
12、 where sno in (selete sno from student where sdept=” 计算机科学系”);31. 建立信息系学生的视图。 create view is_student asselect sno,sname,sage from student where sdept='is';sql语句练习题2设教学数据库education,有三个关系: 学生关系s(sno,sname,age,sex,sdept); 学习关系sc(sno,cno,grade); 课程关系c(cno,cname,cdept,tname)
13、 查询问题: 1:查所有年龄在20岁以下的学生姓名及年龄。select sname,sagefrom swhere sage<20;(not age>=20);2:查考试成绩有不及格的学生的学号 select distinct snofrom scwhere grade<60;3:查所年龄在20至23岁之间的学生姓名、系别及年龄。select sname,sdept,sagefrom swhere sage between 20 and 23;4:查计算机系、数学系、信息系的学生姓名、性别。 select sname,ssex fr
14、om s where sdept in(cs,is,math);5:查既不是计算机系、数学系、又不是信息系的学生姓名、性别 select sname,ssex from s where sdept not in(cs,is,math); 6:查所有姓“刘”的学生的姓名、学号和性别。 select sname,sno,ssex from s where sname like刘%;7:查姓“上官”且全名为3个汉字的学生姓名。 select sname from s where sname like 上官_;8:查所有不姓“张”的学生的姓名。 se
15、lect sname,sno,ssex from s where sname not like 张%;9:查db_design课程的课程号。select cno from c where cname like db_design;10:查缺考的学生的学号和课程号。 select sno,cno from sc where grade is null;11:查年龄为空值的学生的学号和姓名。 select sno,sname from s where sage is null;12:查计算机系20岁以下的学生的学号和姓名。select sno,snamefrom swhere
16、sdept=cs and sage<20;13:查计算机系、数学系、信息系的学生姓名、性别。select sname,ssexfrom swhere sdept=cs or sdept=is or sdept=math;14:查询选修了c3课程的学生的学号和成绩,其结果按分数的降序排列。select sno,gradefrom scwhere cno=c3order by grade desc;15:查询全体学生的情况,查询结果按所在系升序排列,对同一系中的学生按年龄降序排列。select * from sorder by sdep,sage desc;16:查询学生总人数。select
17、 count(*) from s;17:查询选修了课程的学生人数。 select count(distinct sno) from sc18:计算选修了c1课程的学生平均成绩。select avg(grade)from scwhere cno=c1;19:查询学习c3课程的学生最高分数。select max(grade)from scwhere cno=c3;20:查询各个课程号与相应的选课人数。select cno, count(sno)from scgroup by cno; 21:查询计算机系选修了3门以上课程的学生的学号。select snofrom scwher
18、e sdept=csgroup by snohaving count(*)>3; 22:求基本表s中男同学的每一年龄组(超过50人)有多少人?要求查询结果按人数升序排列,人数相同按年龄降序排列。select sage,count(sno)from swhere ssex='m'group by sagehaving count(*)>50order by 2,sage desc;23:查询每个学生及其选修课程的情况。select s.sno, sname, sage, ssex, sdept, cno, gradefrom s, scwhere s.sno
19、=sc.sno;24:查询选修了c2课程且成绩在90分以上的所有学生。select s.sno,snamefrom s,scwhere s.sno=sc.snoand o=c2 and sc.grade>90; 25:查询每个学生选修的课程名及其成绩。select s.sno,sname,cname,sc.gradefrom s,sc,cwhere s.sno=sc.sno and o=o 26:统计每一年龄选修课程的学生人数。 select sage,count(distinct s.sno)from s,scwhere s.sno=sc.snogroup
20、 by sage;27:查询选修了c2课程的学生姓名。select sname from s where sno in(select sno from sc where cno=c2);28:查询与“张三”在同一个系学习的学生学号、姓名和系别。select sno,sname,sdept from where sdept=(select sdept from s where sname=张三); 29:查询选修课程名为“数据库”的学生学号和姓名。select sno,sname from s where sno in(select sno from sc where cno in (
21、select cno from c where cname=db); 30:查询与“张三”在同一个系学习的学生学号、姓名和系别。select sno,sname,sdept from s where sdept=(select sdept from s where sname=张三); 31:查询选修课程名为“数据库”的学生学号和姓名。select sno,sname from s where sno in (select sno from sc where cno=(select cno from c where cname=db);32:查询选修了c2课程的学生姓名。1
22、. select sname from s where sno in(select sno from sc where cno=c2);2. select sname from s where exists(select * from sc where sc.sno=s.sno and cno=c2); 33:查询选修了全部课程的学生姓名。select sname from s where not exists(select * from c where not exists(select * from sc where sc.sno=s.sno and o=o); 36
23、:查询所学课程包含学生s3所学课程的学生学号 select distinct sno from sc as x where not exists(select * from sc as y where y.sno=s3 and not exists(select * from sc as z where z.sno=x.sno and o=o);sql语句练习题 3一、简单查询1、列出全部学生的信息。select * from学生2、列出软件专业全部学生的学号及姓名。select学号,姓名from学生where专业="软件"3、列出所有必修课的课号。select
24、distinct课号from必修课4、求1号课成绩大于80分的学生的学号及成绩,并按成绩由高到低列出。select学号,成绩from选课where课号="1"and 成绩>80 order by成绩desc5、列出非软件专业学生的名单。方法一:select姓名from学生where专业<>"软件"方法二:select姓名from学生where not专业="软件"方法三:select姓名from学生where专业!="软件"6、查询成绩在7080分之间的学生选课得分情况方法一:select*fro
25、m选课where成绩>=70and成绩<=80方法二:select*from选课where成绩between70and80不在此范围内的查询:(注意写出和以下语句等价的语句)select * from 选课 where成绩not between70and807、列出选修1号课或3号课的全体学生的学号和成绩。方法一:select学号,成绩from选课where课号="1"or课号="3"方法二:select学号,成绩from选课where课号in("1","3")相反条件查询:select学号,成绩fro
26、m选课where课号notin("1","3")8、列出所有98级学生的学生成绩情况。select*from选课where学号like"98%"select*from选课where学号like"98_"相反条件查询:select*from选课where学号notlike"98%"9、列出成绩为空值(或不为空值)的学生的学号和课号。答案一:select学号,课号from选课where成绩isnull答案二:select学号,课号from选课where成绩isnotnull10、求出所有学生的总成绩
27、。select sum(成绩) as总成绩 from 选课11、列出每个学生的平均成绩。select学号,avg(成绩) as 平均成绩from选课group by学号12、列出各科的平均成绩、最高成绩、最低成绩和选课人数。select课号,avg(成绩)as平均成绩,max(成绩)as最高分,;min(成绩)as最低分,count(学号) as 选课人数 from 选课 group by 课号二、连接查询(一)简单连接1、列出选修1号课的学生姓名及成绩。select 姓名,成绩 from学生,选课 where学生.学号=选课.学号 and 课号="1"2、列出选修1号课的
28、学生的学号、姓名及成绩。select学生.学号,姓名,成绩from学生s,选课xwheres.学号=x.学号and课号="1"3、求出总分大于150的学生的学号、姓名及总成绩。select学生.学号,姓名,sum(成绩)as总成绩from学生,选课;where学生.学号=选课.学号groupby选课.学号havingsum(成绩)>150(二)自连接查询1、列出那些专业相同的学生相应的姓名及专业信息。select a.姓名,b.姓名,专业from学生a,学生bwherea.学号<>b.学号anda.专业=b.专业2、求至少选修1号课和2号课的学生的学号。s
29、electx.学号from选课x,选课ywherex.学号=y.学号andx.课号="1"andy.课号="2"3、有以下表rate.dbf币种1代码c(2)、币种2代码c(2)、买入价n(8,4)、卖出价n(8,4)外汇汇率.dbf币种1c(4)、币种2c(4)、买入价n(8,4)、卖出价n(8,4)外汇代码.dbf外汇名称c(10)、外汇代码c(10)要求:将所有“外汇汇率”表中的数据插入rate表中并且顺序不变,由于“外汇汇率”中的币种1和币种2存放的是外币名称,而rate表中的币种1代码和币种2代码应该存放外币代码,所以插入时要做相应的改动,外币
30、名称与外向代码的对应关系存储在“外汇代码”表中。selecta.外币代码as币种1代码,b.外币代码as币种2代码,;买入价,卖出价from外汇代码a,外汇汇率,外汇代码b;wherea.外币名称=外汇汇率.币种1andb.外币名称=外汇汇率.币种2intotablerate4、假定有“雇员”表(雇员号c(2),雇员姓名c(6),经理号c(2),根据雇员关系列出上一级经理及其所领导的职员清单。(教案中的例题)select"领导",s.雇员姓名,"雇员",e.雇员姓名from雇员s,雇员ewheres.雇员号=e.经理(三)超连接1、列出选修1号课的学生姓
31、名及成绩。方法一:(使用简单连接查询格式)select姓名,成绩from学生,选课where学生.学号=选课.学号and课号="1"方法二:(使用内部连接格式)select姓名,成绩from学生innerjoin选课on学生.学号=选课.学号where课号="1"方法三:内部连接的inner短语可以省略。(与方法二等价)select姓名,成绩from学生join选课on学生.学号=选课.学号where课号="1"2、查询订货管理数据库中数据的仓库号、城市、供应商名和地址信息。方法一:使用简单连接格式。select仓库.仓库号,城市,供
32、应商名,地址from供应商,订购单,职工,仓库;where供应商.供应商号=订购单.供应商号and订购单.职工号=职工.职工号;and职工.仓库号=仓库.仓库号方法二:使用超连接的内部连接格式。(注意连接条件的顺序)select仓库.仓库号,城市,供应商名,地址from供应商join订购单join职工join仓库;on职工.仓库号=仓库.仓库号on订购单.职工号=职工.职工号on供应商.供应商号=订购单.供应商号3、查询没有选修任何课程的学生姓名。方法一:使用嵌套查询select姓名from学生where学号notin(select学号from选课)方法二:使用超连接的右连接。select姓名
33、from选课rightjoin学生on选课.学号=学生.学号where选课.学号<>学生.学号方法三:使用超连接的左连接。(注意表名顺序和方法二的不同)select姓名from学生leftjoin选课on选课.学号=学生.学号where选课.学号<>学生.学号三、嵌套查询(一)普通嵌套与谓词exists1、列出选修汇编语言课的学生的学号。方法一:select学号from选课where课号=(select课号from课程where课名="汇编语言")方法二:使用谓词exists。注意和方法一格式上的不同。select学号from选课whereexist
34、(select*from课程;where课名="汇编语言"and选课.课号=课程.课号)2、求软件专业所有必修课的课程信息。方法一:select*from课程where课号in;(select课号from必修课where必修专业="软件")方法二:select*from课程whereexist(select*from必修课where必修专业="软件"and课程.课号=必修课.课号)(二)量词any、some、all1、求选修2号课的学生中,成绩比选修1号课的最低成绩要高的学生的学号和成绩。方法一:select学号,成绩from选课wh
35、ere课号="2"and成绩>(selectmin(成绩)from选课where课号="1")方法二:any等价于some,所以可将any换成some。select学号,成绩from选课where课号="2"and成绩>any;(select成绩from选课where课号="1")2、求选修2号课的学生中,成绩比选修1号课的任何学生的成绩都要高的那些学生的学号和成绩。方法一:select学号,成绩from选课where课号="2"and成绩>(selectmax(成绩)from
36、选课where课号="1")方法二:select学号,成绩from选课where课号="2"and成绩>all;(select成绩from选课where课号="1")(三)内外层互相关嵌套(外层依赖于内层的查询结果,内层依赖于外层来进一步查询)1、列出每门课程中成绩最高的选课信息。select*from选课awhere成绩=(selectmax(成绩)from选课bwherea.课号=b.课号)2、列出每个学生中成绩低于本人平均成绩的选课信息。select*from选课awhere成绩<(selectavg(成绩)from
37、选课bwherea.学号=b.学号)3、列出表“订购单2.dbf”(其内容就是在订购单表的基础上增加一个总金额字段)中每个职工经手的具有最高总金额的订购单信息。(教案中例题)selectout.职工号,out.供应商号,out.订货单号,out.订货日期,out.总金额;from订购单outwhere总金额=(selectmax(总金额)from订购单inner1;whereout.职工号=inner1.职工号)四、操作功能1、在课程表中插入新的元组(5,大学英语)。insertinto课程(课号,课名)values("5","大学英语")2、给学生表中男生的记录加上删除标记。deletefrom学生where性别="男"3、将
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 气候变化下的污染控制策略优化-洞察阐释
- 船舶生活区火灾应急预案(3篇)
- 计算机课程学习策略试题及答案
- 林业局火灾应急响应预案(3篇)
- 鼓励积极向上的2024年高考作文试题及答案
- 财政赤字的经济后果与治理试题及答案
- 社区消防火灾应急预案(3篇)
- 行政法学创新试题及答案调查
- 计算机二级VB实现动态表单的题及答案
- 2025年软件设计师考试男女性别差异分析试题及答案
- 《生态环境的密码:竺可桢的科学研究课件》
- 硕士外语水平考试指南与答案
- 2025年入团考试历年总结试题及答案
- 2025年福建省三明市中考二模生物试题(原卷版+解析版)
- 完形填空15篇(答案解析)-2025年中考英语分类专练(深圳专用)
- 2025年服装进货合同范本下载8篇
- 2025年事业单位e类考试真题及答案
- 2024年江苏省宝应县事业单位公开招聘紧缺人才37名笔试题带答案
- 《急性冠状动脉综合征》课件
- 武汉市2025届高中毕业生四月调研考试 试卷与解析
- 2025北京各区高三一模数学分类汇编解析 答案
评论
0/150
提交评论