mysql常用的视图_MySQL视图

MySQL视图的基本操作

视图是数据库中的虚拟表。包含一系列带有名称的行和列数据。视图是从一个或者多个表中导出的,视图的行为与表非常相似,用户可以使用SELECT语句查询数据,以及使用INSERT、UPDATE和DELETE修改记录,视图使用户操作更加方便而且保障数据库系统的安全。

视图一旦定义便存储在数据库中,与其对应的数据并没有像表那样在数据库中再存储一份,通过视图看到的数据只是存放在基本表中的数据。对视图的操作与对表的操作一样,可以对其进行查询、修改和删除。当对通过视图看到的数据进行修改时,相应的基本表的数据也要发生变化,同时若基本表的数据放生变化,则这种变化也会自动地反应到视图中。

创建视图

创建视图的基本语法格式为:CREATE [OR REPLACE] [ALGORITHM={UNDEFINED|MERGE|TEMPTABLE}] VIEW view_name [(column_list)] AS SELECT_statement [WITH [CASCADED|LOCAL] CHECK OPTION] 其中CREATE用来创建新的视图,REPLACE表示替换已经创建的视图,ALGORITHM表示视图选择的算法,view_name为视图名称,column_list为属性列,SELECT_statement表示SELECT语句,WITH[CASCADED|LOCAL] CHECK OPTION参数表示视图在更新时保证在视图的权限范围内。

ALGORITHM的取值有3个,分别是UNDEFINED|MERGE|TEMPTABLE,UNDEFINED表示MySQL将自动选择算法,MERGE表示将使用的视图与视图定义合并起来,使得视图定义的某一部分取代语句对应的部分,TEMPTABLE表示将视图的结果存入临时表,然后用临时表来执行语句。

CASCADED与LOCAL为可选参数,CASCADED为默认参数,表示更新视图时要满足所有相关视图和表的条件,LOCAL表示更新视图时满足该视图本身定义的条件即可。

视图属于数据库。在默认情况下,将在当前数据库创建新视图。想要在给定数据库中明确创建视图,创建时应将名称指定为db_name.view_name.

如下图在单表上创建视图(CREATE VIEW view_student(sID,sName,sAddress) AS SELECT id,name,address FROM tb_student); 选择表tb_student的id,name和address列作为视图view_student的列。

0c86630abb977fbf7e7132939aa754f8.png

若想创建包含学生id,name和班级的视图呢?语法格式为:CREATE VIEW view_s_class(sID,sName,sClass) AS SELECT tb_student.id,tb_student.name,tb_class.name FROM tb_student,tb_class WHERE tb_student.classID=tb_class.id;

1672675ca5fe5d85c46398cf38c39373.png

查看视图

查看视图有4种方式,包括:DESCRIBE、SHOW TABLE STATUS、SHOW CREATE VIEW以及在views表中查看视图详细信息。

DESCRIBE语句查看视图基本信息,语法为:DESCRIBE view_name; 查看view_s_class视图如上上图所示。结果显示视图的字段定义、字段数据类型、是否为空、是否为主外键、默认值和额外信息。

SHOW TABLE STATUS语句查看视图基本信息,语法为:SHOW TABLE STATUS LIKE 'view_name'; 如下图所示,查看view_s_class视图,结果显示,表的说明Comment的值为VIEW说明该表为视图,其他信息为NULL说明这是一个虚表。当查询学生表时,信息包含了存储引擎、创建时间等,Comment信息为空,这就是视图和表的区别。

402bcf059a6521fa5ec8bb314c18de9a.png 

c1a2665a1d49ce59751c1080509577d4.png

SHOW CREATE VIEW语句查看视图详细信息,语法为:SHOW CREATE VIEW 'view_name'; 该语句查看视图的详细定义,结果显示视图的名称、创建数据的语句等信息。

be3b82679ddc063afa873686c155d4dd.png

在视图表中查看详细信息,利用SELECT语句查询information_schema数据库下的views表中存储所有视图的定义。查询语句为:SELECT * FROM information_shcema.views;

b0c59123c1e3b9357b007a5c31e8523f.png

修改视图

修改数据库中存在的视图,当基本表的某些字段发生变化时,可以通过修改视图来保持与基本表的一致性MySQL通过CREATE OR REPLACE VIEW语句和ALTER语句来修改视图。

CREATE OR REPLACE VIEW语句修改视图,语法格式为:CREATE[OR

REPLACE][ALGORITHM={UNDEFINED|MERGE|TEMPTABLE}] VIEW

view_name[(column_list)] AS SELECT_statement [WITH[CASCADED|LOCAL]CHECK

OPTION] 与创建视图的语句完全一样。当视图存在时,修改视图定义;当视图不存在时,创建视图。通过CREATE OR REPLACE对view_student进行修改。

f1c459dc68d740fa85451af471dd6f42.png 

21bddb3bdae7b02c6c96f91c991d38d3.png

ALTER语句修改视图,语法格式为:ALTER

[ALGORITHM={UNDEFINED|MERGE|TEMPTABLE}] VIEW view_name[(column_list)]

AS SELECT_statement [WITH[CASCADED|LOCAL]CHECK OPTION]

如下是通过ALTER语句将view_student视图改为原来的样子。

0407f767ecf3c45358bef7ec42a19313.png

更新视图

更新视图是指通过视图来插入、更新、删除表中的数据,因为视图是一个虚表,其中没有数据。通过视图更新的时候其实是对基本表的更新,本节将介绍视图更新的3种方法:INSERT、UPDATE和DELETE。

INSERT语句向视图中插入数据,代码为:INSERT INTO view_student value(10,'赵云','Hebei');

2a1cc5d8902d38505e3a9b4bb6217466.png

UPDATA语句更新视图中的数据,代码为:UPDATE view_student SET sAddress='Anhui' WHERE sID=8;

166a8337f0606ccc50b52434431ac3ad.png

DELETE删除视图中添加的赵云字段,代码为:DELETE FROM view_student WHERE sID=10;

09b744ecd9346d649afb01b763af8251.png

删除视图

删除一个或多个视图可以使用DROP

VIEW语句,语法格式为:DROP VIEW [IF EXISTS]

view_name[,view_name][RESTRICT|CASCADE]

其中,view_name是要删除的视图名称,可以添加多个视图,各个名称之间使用逗号分隔。如下是删除view_student视图。

685b4118f851a9bee28c4b679d3f6d82.png

MySQL中视图和表的区别和联系

两者的区别

视图是编译好的SQL语句,是基于SQL语句的结果集的可视化的表;

视图没有实际的物理记录,而基本表有;

表是内容,视图是窗口;

表占用物理空间而视图不占用物理空间,视图只是逻辑概念的存在;

视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些SQL语句的集合。从安全的角度说,视图可以防止用户接触数据表。

表属于全局模式中的表,是实表;视图属于局部模式,是虚表;

视图的建立和删除只影响视图本身,但不影响对应的基本表。

两者的联系

视图是在基本表之上建立的表,视图的结构和内容都来自基本表,依赖基本表存在而存在。一个视图可以对应一到多个基本表,是基本表的抽象和在逻辑意义上建立的新关系。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值