共计 3141 个字符,预计需要花费 8 分钟才能阅读完成。
视图是数据库中的虚拟表。包含一系列带有名称的行和列数据。视图是从一个或者多个表中导出的,视图的行为与表非常相似,用户可以使用 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 的列。
若想创建包含学生 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;
- 查看视图
查看视图有 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 信息为空,这就是视图和表的区别。
SHOW CREATE VIEW 语句查看视图详细信息,语法为:SHOW CREATE VIEW ‘view_name’; 该语句查看视图的详细定义,结果显示视图的名称、创建数据的语句等信息。
- 在视图表中查看详细信息,利用 SELECT 语句查询 information_schema 数据库下的 views 表中存储所有视图的定义。查询语句为:SELECT * FROM information_shcema.views;
- 修改视图
修改数据库中存在的视图,当基本表的某些字段发生变化时,可以通过修改视图来保持与基本表的一致性 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 进行修改。
- ALTER 语句修改视图,语法格式为:ALTER [ALGORITHM={UNDEFINED|MERGE|TEMPTABLE}] VIEW view_name[(column_list)] AS SELECT_statement [WITH[CASCADED|LOCAL]CHECK OPTION] 如下是通过 ALTER 语句将 view_student 视图改为原来的样子。
- 更新视图
更新视图是指通过视图来插入、更新、删除表中的数据,因为视图是一个虚表,其中没有数据。通过视图更新的时候其实是对基本表的更新,本节将介绍视图更新的 3 种方法:INSERT、UPDATE 和 DELETE。
- INSERT 语句向视图中插入数据,代码为:INSERT INTO view_student value(10,’ 赵云 ’,’Hebei’);
- UPDATA 语句更新视图中的数据,代码为:UPDATE view_student SET sAddress=’Anhui’ WHERE sID=8;
- DELETE 删除视图中添加的赵云字段,代码为:DELETE FROM view_student WHERE sID=10;
- 删除视图
删除一个或多个视图可以使用 DROP VIEW 语句,语法格式为:DROP VIEW [IF EXISTS] view_name[,view_name][RESTRICT|CASCADE] 其中,view_name 是要删除的视图名称,可以添加多个视图,各个名称之间使用逗号分隔。如下是删除 view_student 视图。
- MySQL 中视图和表的区别和联系
- 两者的区别
- 视图是编译好的 SQL 语句,是基于 SQL 语句的结果集的可视化的表;
- 视图没有实际的物理记录,而基本表有;
- 表是内容,视图是窗口;
- 表占用物理空间而视图不占用物理空间,视图只是逻辑概念的存在;
- 视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些 SQL 语句的集合。从安全的角度说,视图可以防止用户接触数据表。
- 表属于全局模式中的表,是实表;视图属于局部模式,是虚表;
- 视图的建立和删除只影响视图本身,但不影响对应的基本表。
- 两者的联系
- 视图是在基本表之上建立的表,视图的结构和内容都来自基本表,依赖基本表存在而存在。一个视图可以对应一到多个基本表,是基本表的抽象和在逻辑意义上建立的新关系 。
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-04/142499.htm