MySQL 视图学习心得

时间:2024.5.4

一、使用视图的理由是什么?

1.安全性。一般是这样做的:创建一个视图,定义好该视图所操作的数据。之后将用户权限与视图绑定。这样的方式是使用到

了一个特性:grant语句可以针对视图进行授予权限。

2.查询性能提高。

3.有灵活性的功能需求后,需要改动表的结构而导致工作量比较大。那么可以使用虚拟表的形式达到少修改的效果。

这是在实际开发中比较有用的

例子:假如因为某种需要,a表与b表需要进行合并起来组成一个新的表c。最后a表与b表都不会存在了。而由于原来程序中编

写sql分别是基于a表与b表查询的,这就意味着需要重新编写大量的sql(改成向c表去操作数据)。而通过视图就可以做到不修

改。定义两个视图名字还是原来的表名a和b。a、b视图完成从c表中取出内容。

说明:使用这样的解决方式,基于对视图的细节了解越详细越好。因为使用视图还是与使用表的语法上没区别。比如视图名a

,那么查询还是"select * from a"。

4.复杂的查询需求。可以进行问题分解,然后将创建多个视图获取数据。将视图联合起来就能得到需要的结果了。

视图的工作机制:当调用视图的时候,才会执行视图中的sql,进行取数据操作。视图的内容没有存储,而是在视图被引用的时候才派生出数据。这样不会占用空间,由于是即时引用,视图的内容总是与真实表的内容是一致的。

视图这样设计有什么好处?节省空间,内容是总是一致的话,那么我们不需要维护视图的内容,维护好真实表的内容,就可以保证视图的完整性了。

二、通过更新视图实现更新真实表

看到很多例子,更新视图可以更新真实表。原因,我是这样理解的:视图并没有保存内容。只是引用数据。那么,更新视图,其实就是以引用的方式操作了真实表

with check option:对视图进行更新操作的时,需要检查更新后的值是否还是满足视图公式定义的条件。通俗点,就是所更新的结果是否还会在视图中存在。如果更新后的值不在视图范围内,就不允许更新如果创建视图的时候,没有加上with check option,更新视图中的某项数据的话,mysql并不会进行有效性检查。删掉了就删掉了。在视图中将看不到了。

使用有效性检查,实际意义是什么?

视图的实践:重新组织表的需求

CREATE TABLE `result` (`MATH_NO` INT(10) NOT NULL unsigned AUTO_INCREMENT PRIMARY KEY, `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

针对每个表创建一个视图,将数据保存进去:

CREATE VIEW teams(TEAMNO,PLAYERNO,DIVISION) AS SELECT DISTINCT TEAMNO,CAPTAIN,DIVISION FROM result

报错:#1050 - Table 'teams' already exists

说明,因为视图也是一种表,是虚拟表。不能与已有的表(视图)出现重名

接下来,删掉表teams,再执行创建视图的代码。

将视图看成与表一样的东西,更加容易理解使用规则。下面这样对比也许使自己更好理解:

1.在使用视图的时候,就是与使用表的语法一样的。

2.创建视图的时候,该视图的名字如果与已经存在表重名的话,那么会报错,不允许创建。视图就是一种特殊的表

3.创建视图的时候,可以这样使用CREATE VIEW teams(TEAMNO,PLAYERNO,DIVISION),可以定义视图表的结构。

4.在phpmyadmin中。左边的表列表中将视图与表列在了一起。只有通过右侧的状态"View:teams"可以知道该表是视图表。

视图在mysql中的内部管理机制:

视图的记录都保存在information_schema数据库中的一个叫views的表中。具体某个视图的定义代码以及属于哪个数据库等信息可以从里面看到理解视图的两种工作机制:

语句:select * from teams

针对上面语句,总结几个知识点

1.确认是视图的过程:teams也可以是表名。由于表与视图的物理机制不同。视图本身是不存储内容的。所以,在使用sql的

时候,mysql是怎么知道teams是一个视图还是表。是因为有一个查看目录的例程在做这件事。

2.mysql对处理视图的两种方法:替代方式和具体化方式。

替换方式理解,视图名直接使用视图的公式替换掉了。针对上面视图teams,mysql会使用该视图的公式进行替换,视图公式合并到了select中。结果就是变成了如下sql语句: select * from (SELECT DISTINCT TEAMNO,CAPTAIN,DIVISION FROM result)。也就是最后提交给mysql处理该sql语句。

具体化方式理解,mysql先得到了视图执行的结果,该结果形成一个中间结果暂时存在内存中。之后,外面的select语句就调

用了这些中间结果(临时表)。

看起来都是要得到结果,形式上有区别,好像没体会到本质上的区别。两种方式又有什么样的不同呢?

替换方式,将视图公式替换后,当成一个整体sql进行处理了。具体化方式,先处理视图结果,后处理外面的查询需求。

替换方式可以总结为,先准备,后执行。

具体化方式总结理解为,分开处理。

哪种方式好?不知道。mysql会自己确定使用哪种方式进行处理的。自己在定义视图的时候也可以指定使用何种方式。像这样

使用:

CREATE ALGORITHM=merge VIEW teams as SELECT DISTINCT TEAMNO,CAPTAIN,DIVISION FROM result

ALGORITHM有三个参数分别是:merge、TEMPTABLE、UNDEFINED

看mysql手册中提到,替换与具体化的方式的各自适用之处,可以这样理解:

因为临时表中的数据不可更新。所以,如果使用参数是TEMPTABLE,无法进行更新。

当你的参数定义是UNDEFINED(没有定义ALGORITHM参数)。mysql更倾向于选择合并方式。是因为它更加有效。


第二篇:MySQL学习心得


MySQL学习心得

第一章

一、数据库管理系统(DBMS)是操作和管理数据库的大型软件,它按一定的数据模型组织数据。

例如:Oracle、SQL Server、MySQL、Access。

二、数据库应用系统在数据库管理系统(DBMS)支持下建立的计算机应用系统,简写:DBAS。

例如:.net Java。

三、字符集从大到小排序:utf8-- gbk --gb2312。

四、mysql的特点:

适用于中小型网站中,体积小、速度快、总体拥有成本低,尤其是有开放源码这一特点。 五、

目前Internet上浒的网站构架方式是LAMP(Linux+apache+mysql+php)即使用Linux作为操作系统,Apache作为Web服务器,MySQL作为数据库,PHP作为服务器端脚本解释器,由于4个软件都是遵循GPL的开放源码软件,因此使用这种方式不用花一分钱就可以建立起一个稳定、免费的网站系统。

第二章

一、安装过程中遇到的问题及解决方法:

安装过程中没有完成时计算机关机。(没有删除完文件)

安装完成时找不到所配置的路径。(可以从配置文件中找到)

安装完成后无法正常使用。(在计算机管理中重新启动MySQL服务)

安装到一半时没有出现下一步。(误把配置文件删除了)

安装到最后一步时start service错误。

到控制面板里面先把mysql删除.

到c盘C:\Program Files目录下把mysql目录删除.

如果在其他盘还有设置目录也要删除.空目录也要删除

到regedit把注册表

HKEY_LOCAL_MACHINE/SYSTEM/ControlSet001/Services/Eventlog/Applications/MySQL HKEY_LOCAL_MACHINE/SYSTEM/ControlSet002/Services/Eventlog/Applications/MySQL HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Eventlog/Applications/MySQL

有的话,全部删除!(技巧:用F3循环查找“mysql”)

如果任务管理器里有关mysql内容也删除

把防火墙关了

重新装mysql(这里我没有重启计算机)

重装时候有必要的话,重启计算机,停用IIS,和删除temp里的临时文件.

实在不行的话,配置mysql时候,把mysql服务换个服务名.

使用时输入中文会出错。(在配置时在“Character Set”选框中将latinl修改为gb2312;也可以在配置文件中修改)

二、启动服务器的方法:

① 方法1:

在 “计算机管理”中的“服务”项目中启动与停止。

② 方法2:

使用命令(net start mysql和net stop mysql)

三、连接MySQL

格式: mysql -h主机地址 -u用户名 -p用户密码

①先在打开DOS窗口,然后进入目录 mysql\bin(如果设置了环境变量,则直接输入命令即可。)

②键入命令mysql -uroot -proot

③接回车即可进入到MYSQL中了

MYSQL的提示符是:mysql>

注明:直接打开Mysql command line client

四、MySQL注释符有三种:

①#... ②"-- ..." ③

五、忘记密码重新更改密码

先停止mysql服务,修改D:\MySQL\MySQL Server 5.0\ 目录下的my.ini文件,在[mysqld]下添加skip-grant-tables

启动mysql服务后就可以以空密码登录,之后别忘记修改root密码

use mysql

update user set password=password('hanaixia') where user='root';(分号不能少)

password('hanaixia')此处必须用函数设置。

修改密码后需要重新启动服务或者使用 flush privileges;语句,用于从mysql数据库中的授权表重新载入权限。

把 skip-grant-tables 这一句删掉再重启mysql服务。

更多相关推荐:
图书馆心得体会

图书馆业务学习心得体会为了秉承图书馆工作“传播科学知识,弘扬先进文化;以服务求支持,以贡献求发展”这一宗旨,以及致力于提高馆员本职工作业务能力,增进各部门业务间的了解这一原因,本学期开始,图书馆为加强内部学习,…

参加图书馆学习心得体会

参加图书馆学习心得体会通过这次学习,使我对掌握图书馆学情报学基础理论和基本技能有了更进一步的认识。知道了图书馆不仅是传播知识、产生思想、成就人才的知识殿堂,而且是文化的所在,属于社会人文现象之一,弘扬人文精神是…

图书馆业务培训心得体会

我于20xx年x月x日至16日参加了在东沙湖学校由教育局举办的图书馆业务培训。培训内容包括:图书馆管理与服务、中图法,文献分类学、文献编目,中小学图书馆工作流程,图书馆管理实务。几位老师都讲的很仔细,跟我们分…

图书馆读书心得体会

书香扑鼻“书卷多情似故人,晨昏忧乐每相亲。眼前直下三千字,胸次全无一点尘。活水源流随处满,东风花柳逐时新。金鞍玉勒寻芳客,未信我庐别有香”。伟大的民族英雄于谦的一首《观书》,它形象的写出了诗人读书不倦、乐在其中…

图书馆实践心得

这次暑期实践我参加了班里组织的实践活动,此次活动的主要内容是协助图书馆工作人员整理书籍,这对我来说是次很宝贵的实践机会,我也希望我以实际行动,能够体现大学生应有的素质和觉悟。工作人员进行简单的说明后,我和同学先…

《电子图书——超星图书馆》学习心得

电子图书——超星图书馆一、知识点“超星数字图书馆”为目前世界最大的中文在线数字图书馆,提供大量的电子图书资源提供阅读,其中包括文学、经济、计算机等五十余大类,数百万册电子图书,500万篇论文,全文总量13亿余页…

图书馆工作心得体会

图书馆工作心得体会中北大学图书馆(新馆)于xx年竣工。图书馆是中北大学魅力的缩影,也是我校的标志之一。她自建立之日起,就承载了太多人的梦想与期望。每天都有人从图书馆的大门里走出走进,交换着自己与书里的人生,然后…

【精品】 图书馆人员践行三严三实心得体会

精品图书馆人员践行三严三实心得体会三严三实既严以修身严以用权严以律己又谋事要实创业要实做人要实作为一个图书馆人应该在实际工作中践行这种精神把每一个微小工作落到实处把服务意识贯彻到每个工作的细节服务是图书馆工作的...

关于 大学图书馆资源利用的心得

关于大学图书馆资源利用的心得我个人虽算不上一个嗜书如命的书生但还是比较喜欢看书的在课余闲暇时间会去图书馆看上几本杂志再借几本书回寝室简单谈一下自己三年来在和校区图书馆借阅的感受整体来说我们学校的图书馆十分注重自...

图书馆心得

图书馆看书心得120xx02班李凌燕今天是星期五按照惯例又是我们到图书馆学习的时候今天我看的是一本与中国形式与发展相关联的书当前国际局势正在发生深刻的变化和平与发展仍是当今时代的主题世界多极化和经济全球化在曲折...

学习电子书的心得体会

学习电子书的心得体会一知识点超星数字图书馆为目前世界最大的中文在线数字图书馆提供大量的电子图书资源提供阅读其中包括文学经济计算机等五十余大类数百万册电子图书500万篇论文全文总量13亿余页数据总量1000000...

《电子图书——超星图书馆》学习心得

关于超星数字图书馆讲座的心得体会教师研修社区提供的电子图书超星图书馆课程向广大师生展示了图书馆丰富的数字资源使得图书馆的数字资源得到了很好的推广和宣传图书馆众所周知是获取知识自主学习的最佳场所随着科技的发展图书...

图书馆学习心得(29篇)