数据库系统概论|第三章:关系数据库标准语言SQL—课程笔记6

前言

经过前面几篇文章的介绍,已经完成了对于数据查询操作的介绍,接下来,本篇文章将介绍数据更新 这一板块,包括插入数据、修改数据以及删除数据三种操作方法。

注:本文中所涉及的数据库前文中已经介绍(指路:数据库系统概论|第三章:关系数据库标准语言SQL---课程笔记1

一、插入数据

数据插入的语法较为简单,主要运用INSERT 语句,INTO 提示数据将插入的表,VALUES后面接具体要插入的值。

R 复制代码
INSERT
INTO Student (Sno, Sname, Ssex, Sdept, Sage)
VALUES ('201215128', '陈冬', '男', 'IS', 18)

上述代码的含义为++将一个新学生元组(学号:201215128; 姓名:陈冬;性别:男; 所在系:IS; 年龄:18岁)插入到Student表中。++

二、修改数据

在数据修改过程中,核心语句为UPDATE语句,在数据修改过程中,可以仅仅修改一个元组的值,也可以同时修改多个元组的值。

R 复制代码
UPDATE Student 
SET Sage=22
WHERE Sno='201215121' 

上述代码的含义为++更改学生表中,学号为201215121的学生年龄改为22。++

R 复制代码
UPDATE Student 
SET Sage= Sage+1

上述代码的含义为++将学生表中所有学生的年龄均加1。【此处没有WHERE子句,即是更新所有元组】++

R 复制代码
SELECT * 
FROM (SELECT '李勇' AS Sname, 'MA' AS Sdept
	UNION SELECT '刘晨', 'IS') AS T


SELECT *
FROM Student ,(SELECT '李勇' AS Sname, 'MA' AS Sdept
	UNION SELECT '刘晨', 'IS') AS T
WHERE Student.Sname = T.Sname


UPDATE Student 
SET Sdept = T.Sdept
FROM (SELECT '李勇' AS Sname, 'MA' AS Sdept
	UNION SELECT '刘晨', 'IS') AS T
WHERE Student.Sname = T.Sname

上面三段代码层层递进,展示了包含子查询的数据更新语句:

第一段利用集合的并构建了一个临时表T

第二段利用姓名相同,连接了临时表T以及原有表Student

第三段真正展示了数据更新,成功将李勇与刘晨的专业进行更新与修改

三、删除数据

在数据删除的过程中,核心语句为DELETE,同时要指明所删除数据表为哪一个

R 复制代码
DELETE
FROM Student
WHERE Sno= '201215128'

上述代码较为简单,代表++删除学生表中,学号为'201215128'的学生的全部数据。++

R 复制代码
SELECT * 
FROM Student 
WHERE NOT EXISTS(SELECT * FROM SC WHERE Student.Sno = SC.Sno)

DELETE 
FROM Student 
WHERE NOT EXISTS(SELECT * FROM SC WHERE Student.Sno = SC.Sno)

上述两端代码展示了带有子查询的数据删除语句:

第一段利用NOT EXISTS子句选出了那些并没有选课的学生(也就是在SC表中没有的学生)

第二段则是利用这一子查询,删除了Student表中,那些没有选课的学生的记录

相关推荐
7 分钟前
达梦数据库-事务
数据库·达梦数据库·dm
小毅&Nora1 小时前
【人工智能】【深度学习】 ⑦ 从零开始AI学习路径:从Python到大模型的实战指南
人工智能·深度学习·学习
Maxwell_li11 小时前
Pandas 描述分析和分组分析学习文档
学习·数据分析·numpy·pandas·matplotlib
网硕互联的小客服1 小时前
MYSQL数据库和MSSQL数据库有什么区别?分别适用于什么脚本程序?
数据库·mysql·sqlserver
雷工笔记1 小时前
MES学习笔记之SCADA采集的数据如何与MES中的任务关联起来?
笔记·学习
weixin_462446231 小时前
【原创实践】python 获取节假日列表 并保存为excel
数据库·python·excel
繁星星繁2 小时前
【C++】脚手架学习笔记 gflags与 gtest
c++·笔记·学习
RPA 机器人就找八爪鱼2 小时前
RPA 赋能银行数字化转型:四大核心应用场景深度解析
数据库·人工智能·rpa
掂掂三生有幸2 小时前
使用openGauss搭建一个监狱管理系统
数据库
VX:Fegn08952 小时前
计算机毕业设计|基于Java人力资源管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·课程设计