实验九 视图的使用

实验九 视图的使用

一、实验目的

1.熟悉视图的操作。

二、实验内容及要求

用SQL语句完成下列功能。使用数据库为SCHOOL数据库。

1.建立一视图View_CSTeacher,列出计算机系各个老师的资料(姓名、性别、职称)。

sql 复制代码
create view View_CSTeacher(姓名,性别,职称)
as
select teac_id,teac_sex,techpost
from teacher t,deparment d
where t.depar_id=d.depar_id

select * 
from View_CSTeacher

2.建立一视图View_Class,列出每个班级的名称、系别和班级人数。

java 复制代码
```sql
--1.create view必须是批处理中仅有的语句
--解决:加入go
--2.当使用 COUNT() 函数时,您需要指定 GROUP BY 子句来按照哪些字段进行分组

create view View_Class(名称,系别,班级人数)
as
select c.class_name,d.depar_name,count(c.class_id) as '班级人数'
from student s,deparment d,class c
where c.depar_id = d.depar_id and s.class_id = c.class_id
group by c.Class_name,d.Depar_name,s.Class_id
go

select * 
from View_Class

3.建立一视图View_Student,列出每个学生的学号、选修课程门数和平均成绩,并按平均成绩从大到小排列。(体验在视图中使用order by。注意观察视图中数据是否实现按成绩排序?为什么?)

sql 复制代码
--视图中数据并未实现按成绩排序,因为不被允许在视图中使用ORDER BY 。
create view View_Student(学号,选修课程门数,平均成绩)
as
select stu_id,count(course_id) as '选修课程门数',avg(grade) as '平均成绩'
from studentgrade
group by stu_id
go

select * 
from View_Student

drop view View_Student

4.查询平均成绩大于85分的学生的所有信息。(要求使用视图View_Student完成查询)

sql 复制代码
select *
from View_Student
where 平均成绩 >= 85

5.修改视图View_Student(修改视图定义),列出每个学生的学号、姓名、选修课程门数和平均成绩。

sql 复制代码
alter view View_Student
as
select sg.stu_id,s.stu_name,count(sg.Course_id) as '选修课程门数',avg(sg.Grade) as '平均成绩'
from studentgrade sg join student s on sg.stu_id = s.stu_id
group by sg.stu_id,s.stu_name

select * 
from View_Student

6.要通过视图View_Student,将学号为"000503002"的平均成绩改为90分,是否可以实现?并说明原因

sql 复制代码
--对视图或函数 'View_Student' 的更新或插入失败,因其包含派生域或常量域。

update View_Student
set 平均成绩='90'
from View_Student
where  Stu_id='000503002'

7.删除视图View_CSTeacher。

sql 复制代码
drop view View_CSTeacher

8.建一视图View_Studentnum,列出每个班级信息以及班级人数。

sql 复制代码
create view View_Studentnum
as
select c.*,count(s.class_id) as '班级人数'
from class c,student s
where c.class_id = s.class_id
group by c.Class_id,c.Class_id,c.Class_name,c.Depar_id,c.Director,c.Monitor

select * 
from View_Studentnum

三、实验小结

1.试述视图的优点;思考基本表与视图的区别和联系。

视图的优点:

1.视点集中

2.简化操作

3.定制数据

4.合并分割数据

5.安全

视图是一个或多个表依照某个条件组合而成的虚拟集。

2.是否所有视图都可以更新?为什么?举例说明哪些视图不能更新。

并非所有视图都可以更新。比如题目6,含有更新的数据中含有派生域或者常量域是不能更新的。

相关推荐
Metaphor6928 小时前
使用 Python 给 PDF 设置背景色或背景图
数据库·python·pdf
Gauss松鼠会8 小时前
【GaussDB】GaussDB重要通信参数汇总
服务器·网络·数据库·sql·性能优化·gaussdb·经验总结
卷帘依旧9 小时前
JavaScript 判断页面加载完成的多种场景
前端
睡不醒男孩0308239 小时前
第五篇:2026年企业级 PostgreSQL 高可用方案深度横评:Patroni vs. CLup 架构与可靠性全面对决
数据库·postgresql·架构
NineData9 小时前
SQL 都在等锁时,ChatDBA 先帮 MySQL 找到谁在挡路
数据库·人工智能·sql·mysql·安全·数据复制·数据迁移工具
超级无敌zhq9 小时前
后渗透痕迹清理:攻防对抗中的隐身术
网络·数据库·网络安全
光影少年9 小时前
React 项目常见优化方案
前端·react.js·前端框架
2601_961845159 小时前
考研网课资源网盘|2027|资料
数据库·vim·sublime text·figma·photoshop·墨刀·高考
lichenyang4539 小时前
把 demo 里的 console.log 全换成 HiLog:从 %{private} 没脱敏的困惑说起
前端
光影少年9 小时前
组件复用:HOC、Render Props、自定义Hook 对比
前端·react.js·掘金·金石计划