赞
踩
数据更新操作有三种:
在SQL中有相应的三类语句
插入语句INSERT通常有两种形式,一种是插入一个元组,另一种是插入子查询的结果。后者可以一次插入多个元组。
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
修改前:
修改后:
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'
修改前:
修改后:
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
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
use school1
GO
SELECT Sno,Sage
FROM IS_Student
WHERE Sage<20
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'
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。