【SQL实验】高级查询(三)含附加数据库操作

完整代码在文章末尾【代码是自己的解答,并非标准答案,也有可能写错, 文中可能会有不准确或待完善之处,恳请各位读者不吝批评指正,共同促进学习交流**】**


将素材中的"学生管理"数据库附加到SQL SERVER中,完成以下操作:

附加数据库操作:

打开SSMS,在 对象资源管理器中,右击数据库,选择附加

在弹出的 附加数据库窗口中,点击 Add(添加)按钮

浏览到存放数据库文件(.mdf 和 .ldf 文件)的位置。

选择数据库的 .mdf 文件(主数据文件),然后点击 确定

在弹出的窗口中,你会看到数据库的相关信息(如 .mdf 文件的路径、日志文件等)。确认信息正确。如果数据库日志文件(.ldf)也没有出现,系统会自动识别并列出。确认无误后,点击 OK 进行附加。

数据库附加完成

个人因为版本问题附加还原不了,所以导入学生管理.xls文件

导入学生管理.xls文件操作:

右键点击"数据库"节点,选择"新建数据库"。

在弹出的窗口中,设置数据库名称为"学生管理",点击"确定"完成创建

浏览选择文件作为数据库文件路径

导入过程不知道出来什么问题【这个我不知道】,但不要担心,这个步骤是没问题的。

把有问题的删除or重命名

题目:

1.查询大于入学分数平均值的男生的人数

虽然有标红但不影响运行

--1.查询大于入学分数平均值的男生的人数。
SELECT COUNT(*) AS 男生人数
FROM 学生信息
WHERE 性别 = '男'
  AND 入学分数 > (SELECT AVG(入学分数) FROM 学生信息)

2.查询最受学生欢迎(选课人数最多)的课程号、课程名。

外部查询使用 WHERE 条件,筛选出与内部子查询结果相同的课程号,并返回该课程的号和名称

SELECT 课程号,课程名
FROM 课程信息
WHERE 课程信息.课程号 = (
    SELECT TOP 1 学生成绩.课程号
    FROM 学生成绩 
    GROUP BY 学生成绩.课程号
    ORDER BY COUNT(学生成绩.学号) DESC
)

考虑存在并列的情况:

RANK() OVER (ORDER BY COUNT(*) DESC) 根据人数降序排列,并生成排名。

WHERE ranking = 1 过滤出排名第一的课程,即人数最多的课程

3.查询学生考的最好的那门课程情况,显示学号、课程号、成绩(相关子查询)。

外部查询通过 WHERE a.成绩 = ... 匹配最高成绩的记录并返回该课程的学号、课程号和成绩信息。

SELECT 学号, 课程号, 成绩
FROM 学生成绩 a
WHERE a.成绩 = (SELECT MAX(b.成绩) FROM 学生成绩 b)

4.查询"王岩"同学具有相同籍贯的同学,显示姓名,籍贯(使用exists)。

EXISTS 子查询检查条件是否存在

s1.姓名 <> '王岩':排除"王岩"本人,只显示其他同学

SELECT s1.姓名, s1.籍贯
FROM 学生信息 AS s1
WHERE EXISTS (
    SELECT *
    FROM 学生信息 AS s2
    WHERE s1.籍贯 = s2.籍贯 
      AND s2.姓名 = '王岩'
      AND s1.姓名 <> '王岩'
)

5.查询选修了'1001'号课程的学生姓名(使用exists)。

WHERE 学生信息.学号 = 学生成绩.学号:将 学生信息学生成绩 表关联,以确定哪些学生选修了该课程

SELECT 姓名
FROM 学生信息 
WHERE EXISTS (
    SELECT *
    FROM 学生成绩
    WHERE 学生信息.学号 = 学生成绩.学号
      AND 学生成绩.课程号 = 1001
)

完整代码:

--1.查询大于入学分数平均值的男生的人数。
SELECT COUNT(*) AS 男生人数
FROM 学生信息
WHERE 性别 = '男'
  AND 入学分数 > (SELECT AVG(入学分数) FROM 学生信息)

--2.查询最受学生欢迎(选课人数最多)的课程号、课程名
SELECT 课程号,课程名
FROM 课程信息
WHERE 课程信息.课程号=(SELECT TOP 1 学生成绩.课程号
						FROM 学生成绩 
						GROUP BY 学生成绩.课程号
						ORDER BY COUNT(学生成绩.学号) DESC)

--3.查询学生考的最好的那门课程情况,显示学号、课程号、成绩(相关子查询)。
SELECT  学号, 课程号, 成绩
FROM 学生成绩 a
WHERE a.成绩 = (SELECT MAX(b.成绩) FROM 学生成绩 b)

--4.查询"王岩"同学具有相同籍贯的同学,显示姓名,籍贯(使用exists)。
SELECT s1.姓名, s1.籍贯
FROM 学生信息 AS s1
WHERE EXISTS (
    SELECT *
    FROM 学生信息 AS s2
    WHERE s1.籍贯 = s2.籍贯 
		AND s2.姓名 = '王岩'
		AND s1.姓名 <> '王岩'
)

--5.查询选修了'1001'号课程的学生姓名(使用exists)。
SELECT 姓名
FROM 学生信息 
WHERE EXISTS (
    SELECT *
    FROM 学生成绩
    WHERE 学生信息.学号 = 学生成绩.学号
      AND 学生成绩.课程号 = 1001
)
相关推荐
夜泉_ly3 小时前
MySQL -安装与初识
数据库·mysql
qq_529835354 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New6 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6756 小时前
数据库基础1
数据库
我爱松子鱼6 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo7 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser8 小时前
【SQL】多表查询案例
数据库·sql
Galeoto8 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)8 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231118 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql