使用SQL进行集合查询和数据维护

简介: 使用SQL进行集合查询和数据维护

1.分别查询“计科系学生”和“所有男生”的并集,交集和差集。(15分)

–并集

SELECT *
FROM Student
WHERE Sdept='计算机系'
UNION
SELECT *
FROM Student
WHERE Sex='男'
–交集
SELECT *
FROM Student
WHERE Sdept='计算机系'
INTERSECT
SELECT *
FROM Student
WHERE Sex='男'
–差集
SELECT *
FROM Student
WHERE Sdept='计算机系'
EXCEPT
SELECT *
FROM Student
WHERE Sex='男'

2.查询选修了“10001”号课程或选修了“10005”课程的学生学号。(5分)

SELECT Sno
FROM SC
WHERE Cno='10001'
UNION
SELECT Sno
FROM SC
WHERE Cno='10005'

3.查询同时选修了“10001”和“10005” 号课程的学生学号。(5分)

SELECT Sno
FROM SC
WHERE Cno='10001'
INTERSECT
SELECT Sno
FROM SC
WHERE Cno='10005'

4.查询选修了“10001”号课程,但没选“10005” 号课程的学生学号。(5分)

SELECT Sno
FROM SC
WHERE Cno='10001'
EXCEPT
SELECT Sno
FROM SC
WHERE Cno='10005'

Ø *维护操作*

5.在学生表中插入一条新的学生记录,数据可自拟。(注意,插入的数据需满足完整性约束)(5分)

INSERT INTO Student
VALUES('20030101','王芳','女',19 ,'计算机系')

6.插入一条选课记录,学号:10010118,课程号:20008,能否插入成功?为什么?(5分)

INSERT INTO SC(Sno,Cno)
VALUES('10010118','20008')
不能,错误提示:NSERT 语句与 FOREIGN KEY 约束"FK_Sno"冲突。Cno是外键,参照Course中Cno的数值,Course中不存在课程号为“20008”的课程记录。

7.查询每个系及其人数,将查询结果插入到新表Sdept_Count中(10分)

--创建表
CREATE TABLE Sdept_Count(
Sdept varchar(50),
SNum int
)
--插入操作
INSERT INTO Sdept_Count(Sdept,SNum)
SELECT Sdept,COUNT(Sno)
FROM Student
GROUP BY Sdept

8.将学生“徐庆”的所在系修改为“计算机系”(5分)

UPDATE Student
SET Sdept='计算机系'
WHERE Sname='徐庆'

9.将所有课程的学分Credit提高1分。(5分)

UPDATE Course
SET Credit=Credit+1

10.将“徐庆”同学的学号修改为“19010101”,能否修改成功?为什么?(5分)

UPDATE Student
SET Sno='19010101'
WHERE Sname='徐庆'
不能修改成功,因为该生在SC表中存在选课记录。

11.将选修了“计算机基础”这门课的学生成绩提高0.2(10分)

UPDATE SC
SET Score=Score*1.2
WHERE Sno IN(SELECT SNO
FROM SC
WHERE Cno=(SELECT Cno
FROM Course
WHERE Cname='计算机基础'))

12.删除学号为“10010118”的学生记录。能否成功删除?不能删除的原因?如何解决?(10分)

不能删除,原因是SC表中还存在外键的约束,即“10010118”的选课记录。如果要成功删除学生“10010118”,需要先删除其所有选课记录。

DELETE FROM SC
WHERE Sno='10010118'
``
DELETE FROM Student
WHERE Sno='10010118'

13.删除“计算机基础”这门课不及格的选课记录(10分)

DELETE FROM SC
WHERE Score<60 AND Cno=
(SELECT Cno
FROM Course
WHERE Cname='计算机基础')

14.把选课表SC清空。(5分)

DELETE FROM SC
目录
相关文章
|
6天前
|
SQL 安全 数据库
如何在Django中正确使用参数化查询或ORM来避免SQL注入漏洞?
如何在Django中正确使用参数化查询或ORM来避免SQL注入漏洞?
100 77
|
25天前
|
SQL NoSQL Java
Java使用sql查询mongodb
通过使用 MongoDB Connector for BI 和 JDBC,开发者可以在 Java 中使用 SQL 语法查询 MongoDB 数据库。这种方法对于熟悉 SQL 的团队非常有帮助,能够快速实现对 MongoDB 数据的操作。同时,也需要注意到这种方法的性能和功能限制,根据具体应用场景进行选择和优化。
75 9
|
1月前
|
SQL 存储 人工智能
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
Vanna 是一个开源的 Python RAG(Retrieval-Augmented Generation)框架,能够基于大型语言模型(LLMs)为数据库生成精确的 SQL 查询。Vanna 支持多种 LLMs、向量数据库和 SQL 数据库,提供高准确性查询,同时确保数据库内容安全私密,不外泄。
182 7
Vanna:开源 AI 检索生成框架,自动生成精确的 SQL 查询
|
2月前
|
SQL Java
使用java在未知表字段情况下通过sql查询信息
使用java在未知表字段情况下通过sql查询信息
46 8
|
2月前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
82 4
|
2月前
|
SQL 监控 关系型数据库
SQL语句当前及历史信息查询-performance schema的使用
本文介绍了如何使用MySQL的Performance Schema来获取SQL语句的当前和历史执行信息。Performance Schema默认在MySQL 8.0中启用,可以通过查询相关表来获取详细的SQL执行信息,包括当前执行的SQL、历史执行记录和统计汇总信息,从而快速定位和解决性能瓶颈。
|
2月前
|
SQL 存储 缓存
如何优化SQL查询性能?
【10月更文挑战第28天】如何优化SQL查询性能?
206 10
|
2月前
|
SQL 关系型数据库 MySQL
|
2月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
|
3月前
|
SQL 数据库 开发者
功能发布-自定义SQL查询
本期主要为大家介绍ClkLog九月上线的新功能-自定义SQL查询。