SQL——视图

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/carrot_guo/article/details/88073218

视图的特点

  • 虚表,是从一个或几个基本表(或视图)导出的表;
  • 只存放视图的定义,不存放视图对应的数据;
  • 基表中的数据发生变化,从视图中查询出的数据也随之改变;

基于视图的操作

  • 查询
  • 删除
  • 受限更新
  • 定义基于该视图的新视图

定义视图

建立视图

语句格式

子查询不允许含有ORDER BY子句和DISTINCT短语

CREATE VIEW
<视图名> [(<列名> [<列名>])]
AS <子查询>
[WITH CHECK OPTION]

例子

建立信息系学生的视图

CREATE VIEW IS_Student
AS
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept='IS';

建立信息系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有信息系的学生

CREATE VIEW IS_Student
AS 
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept='IS'
WITH CHECK OPTION;

建立信息系选修了1号课程的学生视图

CREATE VIEW IS_Student
AS
SELECT Student.Sno,Sname,Grade
FROM Student,SC
WHERE Sdept='IS'
    AND Student.Sno=SC.Sno
    AND SC.Cno='1';

建立信息系选修了1号课程且成绩在90分以上的学生的视图。

CREATE VIEW IS_S2
AS 
SELECT Sno,Sname,Grade
FROM IS_S1
WHERE Grade>=90;

定义一个反映学生出生年份的视图

CREATE VIEW BT_S(Sno,Sname,Sbirth)
AS
SELECT Sno,Sname,2019-Sage
FROM Student;

将学生的学号及他的平均成绩定义为一个视图假设SC表中“成绩”列Grade为数字型

CREATE VIEW S_G(Sno,Gavg)
AS 
SELECT Sno,AVG(Grade)
FROM SC
GROUP BY Sno;

将Student表中所有女生记录定义为一个视图

缺点:修改基表Student的结构后,Student表与F_Student视图的映象关系被破坏,导致该视图不能正确工作。

CREATE VIEW F_Student(F_Sno,name,sex,age,dept)
AS 
SELECT *
FROM Studnet
WHERE Ssex='女';

删除视图

语句格式

DROP VIEW <视图名>;

查询视图

例子

在信息系学生的视图中找出年龄小于20岁的学生。

SELECT Sno,Sage
FROM IS_Student
WHERE Sage<20;

查询选修了1号课程的信息系学生

SELECT IS_Student.Sno,Sname
FROM IS_Student,SC
WHERE IS_Student.Sno=SC.Sno 
AND SC.Cn='1';

更新视图

例子

将信息系学生视图IS_Student中学号200215122的学生姓名改为“刘辰”

UPDATE IS_Student
SET Sname='刘辰'
WHERE Sno='200215122';

向信息系学生视图IS_S中插入一个新的学生记录:200215129,赵新,20岁

INSERT 
INTO IS_Student
VALUES('200215129','赵新',20);

删除信息系学生视图IS_Student中学号为200215129的记录

DELETE
FROM IS_Student
WHERE Sno='200215129';

视图的作用

猜你喜欢

转载自blog.csdn.net/carrot_guo/article/details/88073218