MySQL视图

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL视图相关的知识,希望对你有一定的参考价值。

1.视图概述:视图是从一个或多个表导出来的表,它是一种虚拟存在的表,并且表的结构和数据都依赖基本表

2.创建视图的语法格式:视图创建基于SELECT语句

CREATE [OR REPLACE] [ ALGORITHM] = {UNDEFINDE | MERGE | TEMPTABLE} ]
VIEW view_name [(column_list)]
AS SELECT_statement
[WITH [ CASCADED | LOCAL] CHECK OPTION]

//OR REPLACE表示该语句可以替换已有视图
//ALGORITHM 表示是视图选择的算法
//UNDEFINDE 表示mysql自动选择算法
//MERGE:将使用视图的语句与视图定义合并起来,是的视图定义的某一部分取代语句的对应部分
//TEMPTABEL:视图存入临时表
//column_list:属性清单,指定了视图中各个属性的名
//AS : 视图要执行的操作
//CASCADED :级联,满足与该视图有关的的所有相关视图和表的条件
//LOCAL : 可选,满足该视图本身定义即可

2.在单表上创建视图

create view play_v as select id,name from star;

select * from play_v;

create view play_v1(number,player) as select id,name from star;

3.在多表上创建视图

create view p_t (number,player,team)
as
select star.id,star.name,team.name from star,team where star.team_id = team.id;

select * from p_t;

4.查看视图

DESCRIBE 视图名称 // 或者 DESC 视图名称
desc play_v1;

SHOW TABLE STATUS LIKE ‘视图名称‘
show table status like ‘p_t‘;

SHOW CREATE VIEW 视图名称;
show create view play_v;

5.修改视图:当基本表中的某些字段发生变化

(1)使用CREATE OR REPLACE VIEW 语句修改视图
create or replace view play_v as select * from student;

(2)
ALTER [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
VIEW view_name [(column_list )]
AS SELECT_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]

~使用alter修改视图结构
alter view play_v1 as select team_id,name from star;

6.更新视图

(1)UPDATE语句
update view p_t set number = null;

(2)INSERT 语句
insert into star values(11,‘克莱-汤普森‘,4); #视图也跟着改变

(3)DELETE语句
delete from p_t where number = 11; #视图删除的数据就是基本表里的数据

7.删除视图

DROP VIEW [IF EXISTS] view_name [,view_name......] [RESTRICT | CASCADE]

drop view play_v1;

以上是关于MySQL视图的主要内容,如果未能解决你的问题,请参考以下文章

mysql中,啥是视图,视图的作用是啥

mysql中的视图

为啥MYSQL很少人用视图,MYSQL的视图和MSSQL的视图有啥本质区别。

关于mysql视图的问题。见补充

mysql视图

mysql视图的作用是啥