⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 3.6 视图例题sql代码.txt

📁 这个软件很不错
💻 TXT
字号:
3.6.1 定义视图(Page 119)

例1:建立信息系学生的视图
CREATE VIEW IS_Student
AS 
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept= 'IS'

例2:建立信息系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有信息系的学生
CREATE VIEW IS_Student
AS 
SELECT Sno,Sname,Sage
FROM Student
WHERE Sdept= 'IS'
WITH CHECK OPTION

例3:建立信息系选修了1号课程的学生视图
CREATE VIEW IS_S1(Sno,Sname,Grade)
AS 
SELECT Student.Sno,Sname,Grade
FROM  Student,SC
WHERE  Sdept= 'IS' AND
       Student.Sno=SC.Sno AND
       SC.Cno= '1'

例4:建立信息系选修了1号课程且成绩在90分以上的学生的视图
CREATE VIEW IS_S2
AS
SELECT Sno,Sname,Grade
FROM IS_S1
WHERE Grade>=90

例5:定义一个反映学生出生年份的视图
CREATE VIEW BT_S(Sno,Sname,Sbirth)
AS 
SELECT Sno,Sname,2004-Sage
FROM Student

例6:将学生的学号及他的平均成绩定义为一个视图,假设SC表中“成绩”列Grade为数字型
CREATE VIEW S_G(Sno,Gavg)
AS  
SELECT Sno,AVG(Grade)
FROM SC
GROUP BY Sno

例7:将Student表中所有女生记录定义为一个视图
CREATE VIEW F_Student(F_Sno,name,sex,age,dept)
AS
SELECT *
FROM Student
WHERE Ssex='女'

例8:删除视图BT_S:DROP VIEW BT_S         
     删除视图IS_S1:DROP VIEW IS_S1
拒绝执行
级联删除DROP VIEW IS_S1 CASCADE

3.6.2 查询视图(Page 121)

例9:在信息系学生的视图中找出年龄小于20岁的学生。
SELECT Sno,Sage
FROM IS_Student
WHERE Sage<20

注:IS_Student视图的定义 (参见视图定义例1);

    视图消解转换后的查询语句为:
SELECT Sno,Sage       
FROM Student
WHERE Sdept= 'IS' AND Sage<20

例10:查询选修了1号课程的信息系学生
SELECT IS_Student.Sno,Sname
FROM IS_Student,SC
WHERE IS_Student.Sno=SC.Sno AND SC.Cno= '1'

例11:在S_G视图中查询平均成绩在90分以上的学生学号和平均成绩
SELECT *
FROM S_G
WHERE Gavg>=90

注:S_G视图的子查询定义: 
CREATE VIEW S_G(Sno,Gavg)
AS 
SELECT Sno,AVG(Grade)
FROM SC
GROUP BY Sno

3.6.3 更新视图(Page 123)

例12:将信息系学生视图IS_Student中学号200215122的学生姓名改为“刘辰”。
UPDATE IS_Student
SET Sname='刘辰'
WHERE Sno='200215122'(学生学号不一样)

转换后的语句:
UPDATE Student
SET Sname='刘辰'
WHERE Sno=' 200215122 ' AND Sdept='IS'

例13:向信息系学生视图IS_S中插入一个新的学生记录:200215129,赵新,20岁
INSERT
INTO IS_Student
VALUES('95029','赵新',20)

转换为对基本表的更新:
INSERT
INTO Student(Sno,Sname,Sage,Sdept)
VALUES('200215129','赵新',20,'IS')

例14:删除信息系学生视图IS_Student中学号为200215129的记录 
DELETE
FROM IS_Student
WHERE Sno='200215129'(学生学号不一样)

转换为对基本表的更新:
DELETE
FROM Student
WHERE Sno='200215129' AND Sdept='IS'

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -