数据库实验:SQL的多表数据查询

news2025/1/24 5:37:58

目录

  • 实验目的
  • 实验内容
  • 实验要求
  • 实验过程
    • 实验代码
    • 结果示意

书接上文,但是感觉之前的形式不太好用,至少不是很方便观看,所以这篇尝试改变一下写法,希望可以提升一些观感

实验目的

(1) 掌握RDBMS的数据多表查询功能
(2) 掌握SQL语言的数据多表查询语句

实验内容

(1) 等值连接查询(含自然连接查询)与非等值连接查询
(2) 自身连接查询
(3) 外连接查询
(4) 复合条件连接查询
(5) 嵌套查询(带有IN谓词的子查询)
(6) 嵌套查询(带有比较运算符的子查询)
(7) 嵌套查询(带有ANY或ALL谓词的子查询)
(8) 嵌套查询(带有EXISTS谓词的子查询)
(9) 集合查询

实验要求

(1) 熟练掌握SQL的连接查询语句
(2) 熟练掌握SQL的嵌套查询语句
(3) 掌握表名前缀、别名前缀的用法
(4) 掌握不相关子查询和相关子查询的区别和用法
(5) 掌握不同查询之间的等价替换方法(一题多解)及限制记录实验结果,认真完成实验报告

实验过程

建立示例数据库S_T(复习)
表Student
学号
Sno 姓名
Sname 性别
Ssex 年龄
Sage 所在系
Sdept
200215121 李勇 男 20 CS
200215122 刘晨 女 19 CS
200215123 王敏 女 18 MA
200215125 张立 男 19 IS
表Course
课程号
Cno 课程名
Cname 现行课
Cpno 学分
Ccredit
1 数据库 5 4
2 数学 2
3 信息系统 5 4
4 操作系统 6 3
5 数据结构 7 4
6 数据处理 2
7 PASCAL语言 6 4
表SC
学号
Sno 课程号
Cno 成绩
Grade
200215121 1 92
200215121 2 85
200215121 3 88
200215122 2 90
200215122 3 80

实验代码

在SQL Server集成管理器的查询窗口中输入如下SQL语句序列来创建示例数据库。
/* 创建示例数据库S_T,包括3个表,即学生表Student、课程表Course和选课表SC*/

create database S_T;
go
use S_T;  /*将S_T设为当前数据库*/
create table Student
     (Sno CHAR(9) PRIMARY KEY,
      Sname CHAR(20) UNIQUE,
      Ssex CHAR(2),
      Sage SMALLINT,
      Sdept CHAR(20)
      );
go

/表Student的主码为Sno,属性列Sname取唯一值/

create table Course
      (Cno CHAR(4) PRIMARY KEY,
       Cname CHAR(40),
       Cpno CHAR(4),
       Ccredit SMALLINT,
       FOREIGN KEY (Cpno) REFERENCES Course(Cno)
       );
go

/表Course的主码为Cno,属性列Cpno(先修课)为外码,被参照表为Course,被参照列是Cno/

create table SC
      (Sno CHAR(9),
       Cno CHAR(4),
       Grade SMALLINT,
       primary key (Sno, Cno),
       FOREIGN KEY (Sno) REFERENCES Student(Sno),
       FOREIGN KEY (Cno) REFERENCES Course(Cno)
       );
go

/表SC的主码为(Sno, Cno), Sno和Cno均为外码,被参照表分别为Student和Course,被参照列分别为Student.Sno和Course.Cno/

insert into student values('200215121','李勇','男',20,'CS');
insert into student values('200215122','刘晨','女',19,'CS');
insert into student values('200215123','王敏','女',18,'MA');
insert into student values('200215125','张立','男',19,'IS');
go

/为表Student添加数据/

insert into course values('1', '数据库', NULL,4);
insert into course values('2', '数学',  NULL,2);
insert into course values('3', '信息系统', NULL,4);
insert into course values('4', '操作系统', NULL,3);
insert into course values('5', '数据结构', NULL,4);
insert into course values('6', '数据处理', NULL, 2);
insert into course values('7', 'PASCAL语言',  NULL,4);
go
update Course set Cpno = '5' where Cno = '1';
update Course set Cpno = '1' where Cno = '3';
update Course set Cpno = '6' where Cno = '4';
update Course set Cpno = '7' where Cno = '5';
update Course set Cpno = '6' where Cno = '7';
go

/为表Course添加数据/

insert into SC values('200215121', '1',92);
insert into SC values('200215121', '2',85);
insert into SC values('200215121', '3',88);
insert into SC values('200215122', '2',90);
insert into SC values('200215122', '3',80);
go

也可以将上述SQL语句序列预先保存在S_T.sql文件中,在SSMS中打开并执行该文件中的sql语句序列
对学生关系Student、课程关系Course和选修关系SC进行多表查询
基本练习
(1)等值连接查询与自然连接查询
例如:查询每个学生及其选修课的情况。

SELECT Student.*, SC.*
FROM Student, SC
WHERE Student.Sno = SC.Sno; /* 一般等值连接 */

又如:查询每个学生及其选修课的情况(去掉重复列)

SELECT Student.Sno, Sname, Ssex, Sage, Cno, Grade
FROM Student, SC
WHERE Student.Sno = SC.Sno;  /* 自然连接--特殊的等值连接 */

(2)自身连接查询
例如:查询每一门课的间接先修课。

SELECT FIRST.Cno, SECOND.Cpno
FROM Course FIRST, Course SECOND
WHERE FIRST.Cpno = SECOND.Cno;

(3)外连接查询
例如:查询每个学生及其选修课的情况(要求输出所有学生–含未选修课程的学生的情况)

SELECT Student.Sno, Sname, Ssex, Sage, Sdept, Cno, Grade
FROM Student LEFT OUTER JOIN SC ON(Student.Sno = SC.Sno);

(4)复合条件连接查询
例如:查询选修了2号课程而且成绩在90以上的所有学生的学号和姓名。

SELECT Student.Sno,Sname
FROM Student,SC
WHERE Student.Sno = SC.Sno AND
         SC.Cno = '2' AND SC.Grade >= 90;

又如:查询每个学生的学号、姓名、选修的课程名及成绩。

SELECT Student.Sno, Sname, Cname, Grade
FROM Student, SC, Course
WHERE Student.Sno = SC.Sno AND
            SC.Cno = Course.Cno;

(5)嵌套查询(带有IN谓词的子查询)
例如:查询与“刘晨”在同一个系学习的学生的学号、姓名和所在系。

SELECT Sno, Sname, Sdept
FROM Student
WHERE Sdept IN 
            (SELECT Sdept
             FROM Student
             WHERE Sname = '刘晨');   /* 解法一*/

可以将本查询中的IN谓词用比较运算符‘=’来代替:

SELECT Sno, Sname, Sdept
FROM Student
WHERE Sdept = 
            (SELECT Sdept
             FROM Student
             WHERE Sname = '刘晨');   /* 解法二*/
             ```
也可以使用自身连接完成以上查询:
```sql
SELECT s1.Sno, s1.Sname, s1.Sdept
FROM Student s1, Student s2
WHERE s1.Sdept = S2.Sdept AND 
             s2.Sname = '刘晨';       /* 解法三*/
还可以使用EXISTS谓词完成本查询:
SELECT Sno, Sname, Sdept
FROM Student S1
WHERE EXISTS
       (SELECT *
        FROM Student S2
        WHERE S2.Sdept=S1.Sdept AND S2.Sname='刘晨'); /* 解法四*/

又如:查询选修了课程名为“信息系统”的学生号和姓名。

SELECT Sno, Sname
FROM Student
WHERE Sno IN 
            (SELECT Sno
             FROM SC
             WHERE Cno IN
                        (SELECT Cno
                         FROM Course
                         WHERE Cname = '信息系统'
                        )
            );
            ```
也可以使用连接查询来完成上述查询:
```sql
SELECT Student.Sno, Sname
FROM Student, SC, Course
WHERE Student.Sno = SC.Sno AND
         SC.Cno = Course.Cno AND
         Course.Cname = '信息系统';

(6)嵌套查询(带有比较运算符的子查询)
例如:找出每个学生超过他所选修课程平均成绩的课程号。

SELECT Sno, Cno
FROM SC x
WHERE Grade >= ( SELECT AVG(Grade)
                 FROM SC y
                 WHERE y.Sno = x.Sno);

(7)嵌套查询(带有ANY或ALL谓词的子查询)
例如:查询其他系中比计算机系某个学生年龄小的学生的姓名和年龄。

SELECT Sname, Sage 
FROM  Student
WHERE Sage <ANY (SELECT Sage
                 FROM Student
                 WHERE Sdept = 'CS')
      AND Sdept <> 'CS';

本查询也可以使用聚集函数来实现:

SELECT Sname, Sage 
FROM  Student
WHERE Sage < (SELECT MAX(Sage)
                 FROM Student
                 WHERE Sdept = 'CS')
      AND Sdept <> 'CS';

又如:查询其他系中比计算机系所有学生年龄都小的学生的姓名和年龄。

SELECT Sname, Sage 
FROM  Student
WHERE Sage <ALL (SELECT Sage
                 FROM Student
                 WHERE Sdept = 'CS')
      AND Sdept <> 'CS';

也可以使用聚集函数来实现:

SELECT Sname, Sage 
FROM  Student
WHERE Sage < (SELECT MIN(Sage)
                 FROM Student
                 WHERE Sdept = 'CS')
      AND Sdept <> 'CS';

(8)嵌套查询(带有EXISTS谓词的子查询)
例如:查询所有选修了1号课程的学生姓名。
111sqlSELECT Sname
FROM Student
WHERE EXISTS
(SELECT *
FROM SC
WHERE Sno=Student.Sno AND Cno=‘1’);

又如:查询所有未选修1号课程的学生姓名。
```sql
SELECT Sname
FROM Student
WHERE NOT EXISTS
               (SELECT *
                 FROM SC
                 WHERE Sno=Student.Sno AND Cno='1');

可以使用带有EXISTS谓词的子查询实现全称量词或蕴涵逻辑运算功能:
例如:查询选修了全部课程的学生姓名。

SELECT Sname
FROM Student
WHERE NOT EXISTS
        (SELECT *
         FROM Course
         WHERE NOT EXISTS
                 (SELECT *
                  FROM SC
                  WHERE Sno=Student.Sno AND
                             Cno=Course.Cno));

又如:查询至少选修了学生200215122选修的全部课程的学生号码。

SELECT DISTINCT Sno
FROM SC SCX
WHERE NOT EXISTS
        (SELECT *
         FROM SC SCY
         WHERE SCY.Sno='200215122' AND
                NOT EXISTS
                   (SELECT *
                    FROM SC SCZ
                    WHERE SCZ.Sno=SCX.Sno AND
                              SCZ.Cno=SCY.Cno));

(9)集合查询
例如:查询计算机系的学生以及年龄不大于19岁的的学生。

SELECT *
FROM Student
WHERE Sdept='CS'
UNION      /*并集运算*/
SELECT *
FROM Student
WHERE Sage<=19;

可以改用多重条件查询:

SELECT *
FROM Student
WHERE Sdept='CS' OR Sage<=19;

又如:查询既选修了课程1又选修了课程2的学生(交集运算)。

SELECT Sno
FROM SC
WHERE Cno='1'
INTERSECT        /*交集运算*/
SELECT Sno
FROM SC
WHERE Cno='2';

可以使用嵌套查询:

SELECT Sno
FROM SC
WHERE Cno='1' AND Sno IN
                       (SELECT Sno
                        FROM SC
                        WHERE Cno='2');

思考:能不能改用多重条件查询?

SELECT Sno
FROM SC
WHERE Cno='1' AND Cno='2';

再如:查询计算机系的学生与年龄不大于19岁的学生的差集。

SELECT *
FROM Student
WHERE Sdept='CS'
EXCEPT        /*差集运算*/
SELECT *
FROM Student
WHERE Sage<=19;

可以改用多重条件查询:

SELECT *
FROM Student
WHERE Sdept='CS' AND Sage>19;

结果示意

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Junit使用

一、Junit常用注释 Test 将一个普通的方法修饰成为一个测试方法。 Test&#xff08;exceptedXX.class&#xff09; Test(exceptedArithmeticException.class):预期被测方法是否抛出ArithmeticException异常Test&#xff08;timeout毫秒&#xff09;BeforeClass&#xff1a;它…

velero备份k8s集群

流程图 velero备份原理 本地 Velero 客户端发送备份指令。Kubernetes 集群内就会创建一个 Backup 对象。BackupController 监测 Backup 对象并开始备份过程。BackupController 会向 API Server 查询相关数据。BackupController 将查询到的数据备份到远端的对象存储。 velero的…

【深度学习】pytorch——Tensor(张量)详解

笔记为自我总结整理的学习笔记&#xff0c;若有错误欢迎指出哟~ pytorch——Tensor 简介创建Tensortorch.Tensor( )和torch.tensor( )的区别torch.Tensor( )torch.tensor( ) tensor可以是一个数&#xff08;标量&#xff09;、一维数组&#xff08;向量&#xff09;、二维数组&…

EasyExcel动态复杂表头导出方法

目录 需求分析解决方案数据问题数据导入 需求分析 公司数据比较特殊有一部分数据需要动态修改导致信息导入时表头是不确定的&#xff0c;但其中又有一部分表头是固定的&#xff0c;如下图所示&#xff0c;如果表头全部是固定的话可以通过EasyExcel实体类的注解很轻松的解决&am…

Linux CentOS7.9安装OpenJDK17

Linux CentOS7.9安装OpenJDK17 一、OpenJDK下载 清华大学开源软件镜像站 国内的站点&#xff0c;下载速度贼快 二、上传解压 文件上传到服务器后&#xff0c;解压命令&#xff1a; tar -zxvf jdk-xxxx-linux-x64.tar.gz三、配置环境 export JAVA_HOME/home/local/java/j…

ffmpeg mp3截取命令,视频与mp3合成带音频视频命令

从00:00:03.500开始截取往后长度到结尾的mp3音频&#xff08;这个更有用&#xff0c;测试好用&#xff09; ffmpeg -i d:/c.mp3 -ss 00:00:03.500 d:/output.mp3 将两个音频合并成一个音频&#xff08;测试好用&#xff09; ffmpeg -i "concat:d:/c.mp3|d:/output.mp3&…

Linux C语言进阶-D10指针数组

指针变量构成的数组 理解下面printf中的a和p的表示&#xff0c;其中p[0]、p[1]、p[2]表示存储的a,a1和a2这几个地址&#xff0c;而再加个*&#xff0c;相当于对地址解引用&#xff0c;从而得到数组中的值。 如下图&#xff0c;要想得到a[0][1]的值可以直接打印a[0][1]&#xf…

使用pytorch处理自己的数据集

目录 1 返回本地文件中的数据集 2 根据当前已有的数据集创建每一个样本数据对应的标签 3 tensorboard的使用 4 transforms处理数据 tranfroms.Totensor的使用 transforms.Normalize的使用 transforms.Resize的使用 transforms.Compose使用 5 dataset_transforms使用 1 返回本地…

YOLOv5:修改backbone为SPPCSPC

YOLOv5&#xff1a;修改backbone为SPPCSPC 前言前提条件相关介绍SPPCSPCYOLOv5修改backbone为SPPCSPC修改common.py修改yolo.py修改yolov5.yaml配置 参考 前言 记录在YOLOv5修改backbone操作&#xff0c;方便自己查阅。由于本人水平有限&#xff0c;难免出现错漏&#xff0c;敬…

一文读懂最小相位滤波器和线性相位滤波器

一文读懂最小相位滤波器和线性相位滤波器 1. 举例说明2. 最小相位定义2.1 最小相位多项式2.2 最大相位滤波器2.3 最小相位意味最快的衰减2.4 最小相位/全通分解 3. 建立最小相位系统 前一篇博客 《一文读懂滤波器的线性相位&#xff0c;全通滤波器&#xff0c;群延迟》 详细解…

curl(二)HTTP协议和头

一 HTTP协议相关 ① 强制发出请求的http1.0 7.29 版本默认是http1.1 ② 查看当前curl版本是否支持http2 方式2: curl --version看Features 补充&#xff1a; 7.33.0 版本才引入 http2,才能使用curl发出http2.0版本的请求 ③ 强制发送http3 说明&#xff1a; 了解即可 二…

DevChat:超越编码的未来 - 优势、安装、使用、以及未来前景

目录 前言1 DevChat的优势1.1 精确的上下文控制1.2 灵活的提示管理1.3 上下文构建1.4 提前准备好的提示模板1.5 高级命令控制 2 安装DevChat插件3 使用DevChat插件3.1 代码生成3.2 文档撰写3.3 解释代码3.4 解决问题3.5 版本控制 4 DevChat的未来前景结语 前言 在软件开发领域…

Docker 多阶段构建的原理及构建过程展示

Docker多阶段构建是一个优秀的技术&#xff0c;可以显著减少 Docker 镜像的大小&#xff0c;从而加快镜像的构建速度&#xff0c;并减少镜像的传输时间和存储空间。本文将详细介绍 Docker 多阶段构建的原理、用途以及示例。 Docker 多阶段构建的原理 在传统的 Docker 镜像构建…

阿里面试:让代码不腐烂,DDD是怎么做的?

说在前面 在40岁老架构师 尼恩的读者交流群(50)中&#xff0c;最近有小伙伴拿到了一线互联网企业如阿里、滴滴、极兔、有赞、希音、百度、网易、美团的面试资格&#xff0c;遇到很多很重要的面试题&#xff1a; 谈谈你的高并发落地经验&#xff1f; 谈谈你对DDD的理解&#xf…

CIM与MES

CIM系统&#xff0c;全称计算机集成制造系统&#xff08;Computer-Integrated Manufacturing&#xff09;&#xff0c;是一种集成了计算机技术、网络通讯技术和软件系统的制造自动化框架。CIM的主要目标是整合制造过程中的所有活动&#xff0c;包括生产管理、设备管理和品质管理…

物流小程序制作教程:从零到有,详细解析

随着互联网的快速发展&#xff0c;物流行业也逐渐实现了数字化转型。为了满足消费者对更加便捷、高效的服务需求&#xff0c;许多物流企业选择制作自己的小程序。本文将通过乔拓云网后台&#xff0c;带你轻松搭建物流小程序&#xff0c;主要分为以下几个部分&#xff1a; 一、进…

设置echarts折线图虚线

itemStyle:{normal: {lineStyle: { type: solid}}}itemStyle:{normal: {lineStyle: { type: dashed}}}放到每个红框里面

梯度消失和梯度爆炸的原因

梯度消失和梯度爆炸 梯度爆炸和梯度消失本质上是因为梯度反向传播中的连乘效应。 梯度下降算法 举一个简单的例子,函数表达式为loss 2w^2 4w,如下图 ​​​​​​​ ​​​​​​​ 为了求得w的最优值,使得loss最小,从上图很容易看出来当w -1时,loss最小…

ER图设计神器,帮你省时省力,高效完成工作!

ER图&#xff08;Entity-Relationship Diagram&#xff09;工具用于设计数据库模型&#xff0c;通常用于表示数据实体、关系和属性之间的关系。以下是10个好用的ER图工具。 一、Lucidchart Lucidchart 是一款基于云的协作式图表设计工具&#xff0c;它允许用户创建、编辑和共享…

SAP发票及复制控制

一、概述 众所周知&#xff0c;SAP为业财一体化的ERP管理系统&#xff0c;因此财务发票必不可少&#xff0c;很多外贸企业还会用到形式发票。 发票相关的配置主要包含&#xff1a;发票类型、复制控制、发票定价以及自动过账的配置。 二、系统配置 1. 发票类型 1.1 概述 发…