Mysql实例mysql视图的学习笔记总结
《Mysql实例mysql视图的学习笔记总结》要点: MYSQL教程本节内容: MYSQL教程一、为何要使用视图 MYSQL教程1.平安性. MYSQL教程3.有灵活性的功能需求后,需要改动表的结构而导致工作量比较大.那么可以使用虚拟表的形式达到少修改的效果. MYSQL教程例子:假如因为某种需要,a表与b表需要进行合并起来组成一个新的表c.最后a表与b表都不会存在了.而由于原来程序中编写sql分别是基于a表与b表查询的,这就意味着需要重新编写大量的sql(改成向c表去操作数据).而通过视图就可以做到不修改.定义两个视图名字还是原来的表名a和b.a、b视图完成从c表中取出内容. MYSQL教程说明:使用这样的解决方式,基于对视图的细节了解越详细越好.因为使用视图还是与使用表的语法上没区别.比如视图名a,那么查询还是"select * from a". MYSQL教程4.复杂的查询需求.可以进行问题分解,然后将创建多个视图获取数据.将视图联合起来就能得到需要的结果了. MYSQL教程视图的工作机制:当调用视图的时候,才会执行视图中的sql,进行取数据操作.视图的内容没有存储,而是在视图被引用的时候才派生出数据.这样不会占用空间,由于是即时引用,视图的内容总是与真实表的内容是一致的. MYSQL教程视图这样设计有什么好处?节省空间,内容是总是一致的话,那么我们不需要维护视图的内容,维护好真实表的内容,就可以保证视图的完整性了. MYSQL教程二、通过更新视图实现更新真实表 MYSQL教程看到很多例子,更新视图可以更新真实表.原因,我是这样理解的:视图并没有保存内容.只是引用数据.那么,更新视图,其实就是以引用的方式操作了真实表 MYSQL教程使用有效性检查的意义 MYSQL教程视图的实践: `TEAMNO` INT(10) NOT NULL, `PLAYERNO` INT(10) NOT NULL, `WON` VARCHAR(10) NOT NULL, `LOST` VARCAHR(10) NOT NULL, `CAPTAIN` INT(10) NOT NULL COMMIT '就是PLAYERNO的另外名字', `DIVISION` VARCHAR(10) NOT NULL ) ENGINE=MYISAM? DEFAULT CHARSET=utf8 COMMIT='重新组的新表' AUTO_INCREMENT=1 MYSQL教程针对每个表创建一个视图,将数据保存进去: MYSQL教程报错:#1050 - Table 'teams' already exists MYSQL教程接下来,删掉表teams,再执行创建视图的代码. MYSQL教程将视图看成与表一样的东西,更加容易理解使用规则.下面这样对比也许使自己更好理解: MYSQL教程1.在使用视图的时候,就是与使用表的语法一样的. MYSQL教程3.创建视图的时候,可以这样使用CREATE VIEW teams(TEAMNO,DIVISION),可以定义视图表的结构. MYSQL教程视图在mysql中的内部管理机制: MYSQL教程视图的记录都保存在information_schema数据库中的一个叫views的表中.具体某个视图的定义代码以及属于哪个数据库等信息可以从里面看到理解视图的两种工作机制: MYSQL教程语句: select * from teamsMYSQL教程针对上面语句,总结几个知识点 MYSQL教程2.mysql对处理视图的两种方法:替代方式和具体化方式. MYSQL教程也就是最后提交给mysql处理该sql语句. MYSQL教程具体化方式理解,mysql先得到了视图执行的结果,该结果形成一个中间结果暂时存在内存中.之后,外面的select语句就调 MYSQL教程用了这些中间结果(临时表). MYSQL教程看起来都是要得到结果,形式上有区别,好像没体会到本质上的区别.两种方式又有什么样的不同呢? MYSQL教程替换方式,将视图公式替换后,当成一个整体sql进行处理了.具体化方式,先处理视图结果,后处理外面的查询需求. MYSQL教程哪种方式好? MYSQL教程mysql会自己确定使用哪种方式进行处理的.自己在定义视图的时候也可以指定使用何种方式.像这样 MYSQL教程使用: MYSQL教程ALGORITHM有三个参数分别是:merge、TEMPTABLE、UNDEFINED MYSQL教程看mysql手册中提到,替换与具体化的方式的各自适用之处,可以这样理解: 欢迎参与《Mysql实例mysql视图的学习笔记总结》讨论,分享您的想法,编程之家PHP学院为您提供专业教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |