数据库实验三 Sql多表查询和视图

数据库实验三 Sql多表查询和视图

    • 一、Sql表
    • 二、在线练习

一、Sql表

在这里插入图片描述
www.db-book.com
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

二、在线练习

对所有表执行查询语句,查看有哪些数据。
select * from tableName;
一、执行以下查询语句,写出查询意图。
(1) select * from student,takes
where student.ID = takes.ID
根据学号连接stduent表和takes表进行查询

(2) select * from student natural join takes
stduent表和takes表进行自然连接后进行查询

(3) select * from student natural left outer join takes
stduent表自然左接takes表后进行查询

(4) select ID
from student natural left outer join takes
where course_id is null
stduent表自然左接takes表后查询课程id为空的学生id

(5)select name,instructor.dept_name,building
from instructor,department
where instructor.dept_name = department.dept_name
将instructor表和department表中instructor.dept_name和department.dept_name进行等值连接,然后查询表中name,instructor.dept_name,building等信息

(6)select name,course_id
from instructor,teaches
where instructor.ID=teaches.ID
将instructor表和teaches表中instructor.ID和teaches.ID进行等值连接,然后查询表中name,course_id等信息

(7)create view faculty as
select ID,name,dept_name
from instructor
创建一个包含instructor中select ID,name,dept_name数据的视图

(8)select * from faculty
查询faculty视图

(9)create view phy_fall_2017 as
select course.course_id,sec_id,building,room_number
from course,section
where course.course_id = section.course_id
and course.dept_name = ‘Physics’
and section.semester =‘Fall’
and section.year = ‘2017’
创建一个列出Physics系在2017年秋季学期所开设的所有课程段,以及每个课程段在那栋建筑的那个房间授课的信息的视图

(10) select * from phy_fall_2017
查询from phy_fall_2017视图

(11) drop view phy_fall_2017
删除phy_fall_2017视图

(12)
create view dept_total_salary(dept_name,total_salary)
as
select dept_name,sum(salary)
from instructor
group by dept_name
创建一个dept_total_salary视图,并且以dept_name,total_salary作为表头,其中的数据从instructor的dept_name,sum(salary)获取,并且按dept_name分组

(13) select * from dept_total_salary
查询dept_total_salary视图

二、写出SQL查询语句
(14)找出名叫Einstein的教师所教授的所有学生的学号,保证结果中没有重复。
select ID
from student
where student.ID in (select s_ID
from advisor join instructor
on i_ID in(
select ID
from instructor
where name=‘Einstein’));

(15)找出2017年秋季开设的每个课程的选课人数。
select course_id, sec_id, count(ID)
from section natural join takes
where semester = ‘Fall’ and year = 2017
group by course_id, sec_id

(16)从2017年秋季开设的所有课程段中,找出最多的选课人数。
select Max(cnt)
from (
select Count(ID) as cnt
from section natural join takes
where semester = ‘Fall’ and year = 2017 group by course_id, sec_id
)

(17)找出2017年秋季选课人数最多的课程编号。
with Fall_2017 as
(
select course_id, sec_id, count(ID) as cnt
from section natural join takes
where semester = ‘Fall’ and year = 2017
group by course_id, sec_id
)
select course_id,sec_id
from Fall_2017
where cnt = (select max(cnt) from Fall_2017)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/209945.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

YOLOv7独家改进: Inner-IoU基于辅助边框的IoU损失,高效结合 GIoU, DIoU, CIoU,SIoU 等 | 2023.11

💡💡💡本文独家改进:Inner-IoU引入尺度因子 ratio 控制辅助边框的尺度大小用于计算损失,并与现有的基于 IoU ( GIoU, DIoU, CIoU,SIoU )损失进行有效结合 推荐指数:5颗星 新颖指数:5颗星 收录: YOLOv7高阶自研专栏介绍: http://t.csdnimg.cn/tYI0c …

Redis -- 介绍

1、NoSQL: 指的是非关系型数据库,主要分成四大类:键值存储数据库、列存储数据库、文档型数据库、图形数据库。 2、什么是Redis: Redis是一种基于内存的数据库,一般用于做缓存的中间件。 3、Redis的主要的特点: 1、Rd…

投标文件如何写【格式层面】

一、顶级标题的修改(1级标题的修改) 修改的内容,核心是样式多级序号; 样式解决;标题1,标题2,解决快速排版的问题 多级标号解决如1.1,1.2.1,1.3.4等类似的自动编号的规划设置,如果…

Oracle-客户端连接报错ORA-12545问题

问题背景: 用户在客户端服务器通过sqlplus通过scan ip登陆访问数据库时,偶尔会出现连接报错ORA-12545: Connect failed because target host or object does not exist的情况。 问题分析: 首先,登陆到连接有问题的客户端数据库上,…

【实用】PPT没几页内存很大怎么解决

PPT页数很少但导出内存很大解决方法 1.打开ppt点击左上角 “文件”—“选项” 2.对话框选择 “常规与保存” (1)如果想要文件特别小时可 取消勾选 “将字体嵌入文件” (2)文件大小适中 可选择第一个选项 “仅最入文档中所用的字…

Java大型电商项目——品优购(一)

视频教程:【黑马程序员】Java大型电商项目—品优购【配套源码笔记】_哔哩哔哩_bilibili源码下载: 链接:https://pan.baidu.com/s/1fECz5In_XCB-aW6ed6ZTbA 提取码:27xa 技术选型: 后端框架:SpringSprin…

spring-boot-admin-starter-server监控springboot项目

文章目录 场景实现具体操作展示 场景 监控三件套Prometheus、Grafana、Alertmanager 部署起来太复杂,如果公司没有运维而且项目很小就可以使用spring-boot-admin-starter-server替代。这个包使用起来还是很简单的, 下面就实现一个对springCloud项目的监控 实现 参考 项目 具体操…

redis-cluster集群(目的:高可用)

1、特点 集群由多个node节点组成,redis数据分布在这些节点中,在集群中分为主节点和从节点,一个主对应一个从,所有组的主从形成一个集群,每组的数据是独立的,并且集群自带哨兵模式 2、工作原理 集群模式中…

【SpringBoot篇】Spring_Task定时任务框架

文章目录 🌹概述🌺应用场景🎄cron表达式🛸入门案例🎍实际应用 🌹概述 Spring Task 是 Spring 框架提供的一种任务调度和异步处理的解决方案。可以按照约定的时间自动执行某个代码逻辑它可以帮助开发者在 S…

电脑开机显示器没反应?5个方法轻松解决!

“各位朋友们,我想问问,电脑开机显示器没反应是为啥呢?有什么方法可以解决这个问题吗?感谢感谢!” 在使用电脑时,用户可能会遇到各种各样的情况。电脑开机显示器没反应也是一个比较常见的电脑问题。遇到这种…

c语言:回文字符串

题目: 思路: 创建一个字符数组,然后判断字符串长度,用循环,看对应字符是否相等,相等则输出,不相等则将对应字符ascll较大的改成ascll较小的(题目要求字典最小的情况)。…

【Vue入门篇】基础篇—Vue指令,Vue生命周期

🎊专栏【JavaSE】 🍔喜欢的诗句:更喜岷山千里雪 三军过后尽开颜。 🎆音乐分享【如愿】 🎄欢迎并且感谢大家指出小吉的问题🥰 文章目录 🍔Vue概述🎄快速入门🌺Vue指令⭐v-…