- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
MySQL数据库基础与实例教程第7章教程
;1;作业; 视图与表有很多相似的地方,视图也是由若干个字段以及若干条记录构成,视图也可以作为select语句的数据源。甚至在某些特定条件下,可以通过视图对表进行更新操作。;1;6;创建视图的语法格式如下。
create view 视图名 [ (视图字段列表) ]
as
select语句
对于经常使用的、结构复杂的select语句,建议将其封装为视图 ”.简化数据查询操作。
;7.1.1 创建视图;任务布置1: “对于经常使用的、结构复杂的select语句,建议将其封装为视图 ”。
例如:为统计每门课程还能供多少同学选修,定义名为 available_course_view的视图。
;create view available_course_view
AS
select course.course_no,course_name,teacher_name,
up_limit,count(*) as student_num,
up_limit-count(*) as available
from teacher inner join course
on teacher.teacher_no=course.teacher_no
inner join choose
on choose.course_no=course.course_no
group by course.course_no;
Select * from available_course_view;;可以使用下面四种方法查看视图的定义。 1.在choose数据库中成功地创建了视图available_course_view后,该视图的定义默认保存在数据库目录(例如choose目录)下,文件名为available_course_view.frm。使用记事本打开该文件,即可查看该视图的定义。;可以使用下面四种方法查看视图的定义。 2.视图是一个虚表,也可以使用查看表结构的方式查看视图的定义 desc v1_view。
3.MySQL命令“show tables;”命令不仅显示当前数据库中所有的基表,也会将所有的视图罗列出来。;可以使用下面四种方法查看视图的定义。 4.MySQL系统数据库information_schema的views表存储了所有视图的定义,使用下面的select语句查询该表的所有记录,也可以查看所有视图的详细信息。
select * from information_schema.views\G;原来的course表的结构: dese course;
从现在开始,新课程course表中比原来的课程course表多了一个“剩余的学生名额”available字段。
任务布置2:上机操作,完成本书场景描述2的任务要求。
;7.1.3 视图在“选课系统”中的应用;7.1.3 视图在“选课系统”中的应用;4、查询course表的信息
select course_no,course_name,up_limit,available
from course;
;1.使操作变得简单
2.避免数据冗余
3.增强数据安全性
4.提高数据的逻辑独立性;如果某个视图不再使用,可以使用drop view语句将该视图删除,语法格式如下。
drop view 视图名;视图分为普通视图与检查视图,没有使用‘with check optiom’子句的视图都是普通试图。
通过检查视图更新基表数据时,只有满足检查条件的更新语句才能成功执行。创建检查视图的语法格式如下。
create view 视图名 [ (视图字段列表) ]
as
select语句
with [ local | cascaded ] check option;任务布置3:上机操作,完成本书场景描述3:普通视图与更新操作的任务要求。
创建成绩不及格的选修试图choose_1_view
create view choose_1_view as select * from choose where score60;
;一、插入数据
insert into choose_1_view values null,2012003,2,100,now());
select * from choose;
Select * from choose_1_view;
;二、删除数据
delete from choose where student_no=2012003 and course_no=2;
Select * from choose;
Select * from choose_1_view;
普通视图不具备”检查”功能.
;7.1.6 检查视图;然后分析普通视图与检查视图之间的区别。
定义的格式不同.
更新基表数据时,
文档评论(0)