SQL语言(二)数据更新

本文详细介绍了SQL中的数据操作,包括向表中插入数据、修改现有数据和删除数据。使用INSERT语句进行单个和批量插入,UPDATE语句用于修改数据,而DELETE语句用于删除数据行。此外,还讨论了视图的概念,如何创建、更新和删除视图,以及如何通过视图查询和操作数据。这些基本操作对于理解和管理数据库至关重要。
摘要由CSDN通过智能技术生成

数据更新

数据更新操作有三种:

  • 向表中添加若干行数据
  • 修改表中的数据
  • 删除表中的若干行数据

在SQL中有相应的三类语句

插入数据

插入语句INSERT通常有两种形式,一种是插入一个元组,另一种是插入子查询的结果。后者可以一次插入多个元组。

插入元组

将一个新学生元组插入到Student表中
use school1
GO
INSERT
INTO Student(Sno,Sname,Ssex,Sdept,Sage)
VALUES('S07','陈冬','男','软件工程',18)

修改前:
在这里插入图片描述
修改后:
在这里插入图片描述

对每一个系,求学生的平均年龄,并把结果存入数据库

首先在数据库中建立一个新表,其中一列存放系名,另一列存放相应的学生平均年龄。

CREATE TABLE Dept_age
         (Sdept CHAR(15)
		    Avg_age SMALLINT)

然后对Student表按系分组表示平均年龄,再把系名和平均年龄存入新表中。

INSERT 
INTO Dept_age(Sdept,Avg_age)
SELECT Sdept.AVG(Sage)
FROM Student
GROUP BY Sdept

修改数据

将学生的年龄改为22岁

修改前:
在这里插入图片描述
修改后:
在这里插入图片描述

将所有学生的年龄都增加一岁
use school1
GO
UPDATE Student
SET Sage=Sage+1
将计算机科学系全体学生的成绩置零
use school1
GO
UPDATE SC
SET Grade=0
WHERE Sno IN 
     (SELECT Sno
	  FROM Student
	  WHERE Sdept='计算机'	 
	 )

删除数据

删除某一个学生的学生记录

use school1
GO
DELETE 
FROM Student
WHERE Sno='S07'

修改前:
在这里插入图片描述
修改后:
在这里插入图片描述

空值处理

选出选修1号课程的不及格的学生及缺考的学生
use school1
GO
SELECT Sno
FROM SC
WHERE Grade<60 AND Cno='C01'
UNION
SELECT Sno
FROM SC
WHERE Grade IS NULL  AND Cno='CO1'

视图

定义视图

建立数学系学生的视图
use school1
GO
CREATE VIEW IS_Student
AS
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept='数学'

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

建立数学系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有数学系的学生
use school1
GO
CREATE VIEW IS_Student
AS
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept='数学'
WITH CHECK OPTION
建立自动化系选修了1号课程的学生的视图(包括学号、姓名、成绩)
use school1
GO
CREATE VIEW IS_S1tudent(Sno,Sname,Grade)
AS
SELECT Student.Sno,Sname,Grade
FROM Student,SC
WHERE Sdept='自动化'AND Student.Sno=SC.Sno AND SC.Cno='C01'

定义一个反映学生出生年份的视图
use school1
GO
CREATE VIEW BT_S(Sno,Sname,Sbirth)
AS
SELECT Sno,Sname,2014-Sage
FROM Student

在这里插入图片描述

将学生的学号及平均成绩定义为一个视图
use school1
GO
CREATE VIEW S_G(Sno,Gavg)
AS
SELECT Sno,AVG(Grade)
FROM SC
GROUP BY Sno

在这里插入图片描述

删除视图

删除视图BT_S和视图IS_SI

use school1
GO
DROP VIEW BT_S
DROP VIEW IS_S1tudent

查询视图

在数学系学生的视图中找出年龄小于20岁的学生
use school1
GO
SELECT Sno,Sage
FROM IS_Student
WHERE Sage<20

在这里插入图片描述

在S_G视图中查询平均成绩在80分以上的学生学号和平均成绩
use school1
GO
SELECT Sno,AVG(Grade)
FROM SC
GROUP BY Sno
HAVING AVG(Grade)>=80

在这里插入图片描述

更新视图

更新视图是指通过视图来插入、删除和修改数据。
由于视图是不实际存储数据的虚表,因此对视图的更新最终要转换为对基本表的更新
将数学系学生视图IS_Student中学号为“S06”的学生姓名改为“长江”

use school1
GO
UPDATE IS_Student
SET Sname='长江'
WHERE Sno='S06'  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值