当前位置: 首页 > news >正文

贵阳建站模板wordpress 链接跳转

贵阳建站模板,wordpress 链接跳转,wordpress 百度站长,如何启动wordpress目录 检索查询 题目一 题目二 题目三 题目四 题目五 题目六 题目七 题目八 题目九(本篇最难的题目) 分析 实现(两种方式) 模板 总结 检索查询 按照要求查找数据库中的数据 题目一 找出没有选修任何课程的学…

目录

检索查询

题目一

题目二 

题目三 

题目四 

题目五

题目六 

题目七

题目八 

题目九(本篇最难的题目)

分析

实现(两种方式)

 模板

总结 


检索查询

按照要求查找数据库中的数据

题目一

找出没有选修任何课程的学生的学号、姓名(即没有选课记录的学生)

select sid,name
from pub.student
where sid in ((select sid from pub.student)minus(select distinct sidfrom pub.student_course)
)

关键点:

1、没有选修任何课的学生=所有学生-选了课的学生

所有学生:select sid from pub.student

选了课的学生:select distinct sid  from pub.student_course

2、减号就是minus关键字

题目二 

找出至少选修了学号为“200900130417”的学生所选修的一门课的学生的学号、姓名(不包含这名同学)。

select sid,name
from pub.student
where sid in((select distinct sidfrom pub.student_coursewhere cid in (select cidfrom pub.student_coursewhere sid='200900130417'))minus(select sidfrom pub.studentwhere sid='200900130417')
)

关键点:

找“200900130417”学号的学生选修的全部课程——》找pub.student_course中cid在全部课程中的选课记录——》拿出sid在pub.student中进一步获取name

题目三 

找出至少选修了一门其先行课程号为“300002”号课程的学生的学号、姓名。

 select sid, namefrom  pub.studentwhere sid in(select sidfrom pub.student_coursewhere cid in ( select cidfrom pub.student_coursewhere pcid='300002')
)

关键点:

1、找先行课程号为“300002”号的课程——》找pub.student_course中cid在前面课程中的选课记录——》拿出sid在pub.student中进一步获取name

2、题目二和题目三的思路是相似的

题目四 

找出选修了“操作系统”并且也选修了“数据结构”,但是没有选修“程序设计语言”的学生的学号、姓名。

select sid,namefrom pub.studentwhere sid in((select sidfrom pub.student_coursewhere cid=(select cidfrom pub.coursewhere name='操作系统'))intersect(select sidfrom pub.student_coursewhere cid=(select cidfrom pub.coursewhere name='数据结构'))minus(select sidfrom pub.student_coursewhere cid=(select cidfrom pub.coursewhere name='程序设计语言')))

关键点:

1、干了A,并且干了B,但没有干C=A的结果 交 B的结果 减 C的结果

2、intersect关键字:取交集

题目五

 找出姓名叫“李龙”的学生的学号及其选修全部课程的课程号、课程名和成绩。

create view test3 as
select sid,cid,pub.course_name,score
from pub.student natural join pub.student_course natural join pub.course
where pub.student_name='李龙'
create view test2_05 asselect sid,cid,name,scorefrom pub.student_course natural join pub.coursewhere sid in(select sidfrom pub.studentwhere name='李龙')

关键点

1、 第一个代码是错误的。因为pub.student和pub.course中都有name属性,而这两者自然连接显然是不合理的

2、将三个自然连接拆为:两个自然连接+一个嵌套select语句

题目六 

查询2010级、计算机科学与技术学院、操作系统的学生成绩表,内容有学号、姓名、成绩。

  select sid,name,scorefrom pub.student_course natural join pub.studentwhere class='2010' and dname='计算机科学与技术学院' and cid=(select cidfrom pub.coursewhere name='操作系统')

关键点:

1、同样考察自然连接的应用 

题目七

查询所有不姓张、不姓李、也不姓王的学生的学号sid、姓名name

select sid,name
from pub.student
where name not like '张%'
and name not like '李%'
and name not like '王%'

关键点:

1、 不姓A=not like ‘A%'

2、 名字不叫B=not like ‘%B’

题目八 

找出有间接先行课的所有课程的课程号、课程名称。

select cid ,name
from pub.course
where fcid in (select cidfrom pub.coursewhere fcid is not NULL
)

关键点:

1、 不为空=is not NULL

2、间接关系的处理(例:祖孙关系)

题目九(本篇最难的题目)

找出选修了所有课程的学生的学号、姓名。

分析

第一想法:拿出所有课程——》令pub.student_course(选用sid,cid)除取所有课程(cid)——》得到sid,这个sid'所选用的课程就是全部课程

问题是:SQL语言不提供直接可以用的除运算

实现(两种方式)

方法一、

select sid,name
from pub.student
where not exists(select cidfrom pub.coursewhere not exists(select * from pub.student_coursewhere pub.student_course.cid=pub.course.cid and pub.student_course.sid=pub.student.sid)
)

方法二、

select sid,name
from pub.student
where not exists((select cidfrom pub.course)minus(select cidfrom pub.student_coursewhere pub.student_course.sid=pub.student.sid)
)

 模板

查询做了所有(至少)A的B

SELECT * FROM S
WHERE NOT EXISTS(SELECT * FROM C WHERE C.`cno` IN ('C001','C002')AND NOT EXISTS(SELECT * FROM SCWHERE SC.`cno` = C.`cno` AND SC.`sno` = S.`sno` )
)

总结 

本文的所有题目均来自《数据库系统概念》(黑宝书)、山东大学数据库实验二。不可用于商业用途转发。

如果能帮助到大家,大家可以点点赞、收收藏呀~ 

http://www.yayakq.cn/news/752895/

相关文章:

  • 计算机应用技术php网站开发哪个网站的pc端是用vue做的
  • windows 网站开发上海公关公司排名
  • 阿克苏市建设局网站wordpress评论数据库分离
  • 淘宝客网站需要备案鼓楼机关建设网站
  • 模仿网站建设网站维护工作方案
  • 京东淘宝网站是怎么做的韩国网站 后缀
  • 做摄影和后期的兼职网站德兴市网站建设服务公司
  • 学校网站建设先进事迹一般做海报的图片跟哪个网站下载
  • 门图书馆户网站建设方案jsp网站开发教学视频
  • 网站建设规划书参考模板网站域名ip地址查询
  • 网站怎么做浏览量才会多wordpress图片网站
  • 石家庄的网站建设公司哪家好有做浏览单的网站
  • 做优化网站注意什么小企业网站建设方案
  • 修改网站dns公司网站搭建流程
  • 张掖市作风建设年活动网站设计上海兼职网站建设
  • 站内seo是什么意思西安网站建设麦欧科技
  • 西安哪家公司做网站网站建设背景怎么设置成
  • 58同城做网站电影网站如何优化
  • 淄博市沂源县城乡建设局网站网站制作的要求
  • 做室内设计的网站有哪些方面湛江建网站
  • 如何跟进网站建设的客户网站自动更新文章
  • 网站建设注册成都vi设计公司
  • 网站备案备注信息wordpress 后门软件
  • 给前端做网站的图片叫什么软件廉政网站建设
  • 东莞网站建设信科steam官方网站下载
  • 做58网站怎么赚钱吗互动营销网站
  • 网站上做扫一扫自己怎么做网址开网站
  • 百度推广网站备案公司做网站要花多少钱
  • 广州 行业 网站建设重庆的网站设计公司
  • 自己做返利网站深圳网站优化多少钱