🙉 作者简介: 全栈领域新星创作者 ;天天被业务折腾得死去活来的同时依然保有对各项技术热忱的追求,把分享变成一种习惯,再小的帆也能远航。
🏡 个人主页:xiezhr的个人主页
🔥 专栏地址:必知必会的MySQL知识
一、视图
(1)视图是一个虚拟的表,是从数据库中一个或多个表中导出来的表
(2)数据库中只存放了视图的定义,而并没有存放视图的数据,这些数据存在于原来的表中
(3)使用视图查询数据时,数据库系统会从原来数据表中取出数据
二、视图的作用
(1)使操作简便化
(2)增加数据的安全性
(3)提高表的逻辑独立性
三、创建视图
-- 语法格式
create [algorithm = {undefiend | temptable}]
view 视图名 [(属性清单)]
as select 语句
[with [cascaded | local] check option];
-- algorithm 是可选参数,表示视图选择的算法
-- “视图名”参数表示要创建的视图的名称
-- “属性清单”是可选参数,其指定了视图中各种属性的名词
-- select语句参数是一个完整的查询语句,标识从某个表查询出满足条件的记录,将这些记录导入视图中;
-- with check option 是可选参数,表更新视图时要保证在视图权限范围之内
-- algorithm 包括三个选项 undefined、merge和temptable
-- {undefined -->MySQL将自动选择要使用的算法
-- merge -->将使用视图的语句与视图定义合并起来,使得视图定义某一部分取代语句的对应部分
-- temptable-->将视图的结果存入临时表,然后使用临时表执行语句
-- cascaded -->是可选参数,表示更新视图时要满足所有关于视图和表的条件,该参数为默认值
-- local -->更新视图时,依靠满足该视图本身定义条件即可
-- }
例子:
create view v1 as select bookName,price from t_book;
四、查看视图
(1)describe 语句查看视图基本信息
(2)show table status语句查看视图基本信息
(3)show create view语句查看视图详细信息
(4)在view表中查看视图详细信息
五、修改视图
(1)create or replace view 语句修改视图
create or replace [algorithm={undefiend | merge | temptable}]
view 视图名 [(属性名)]
as select 语句
[with [cascaded local ]check option]
(2)alter 语句修改视图
alter [algorithm={undefiend | merge | temptable }]
view 视图名 [(属性名)]
as select 语句
[with [cascaded local ]check option]
六、更新视图
更新视图是指通过视图来插入(insert),更新(update)和删除(delete)表中的数据。因为视图是一个
虚拟的表,其中没有数据,通过视图更新时,都是转换为基本表更新。更新视图时,只能更新权限范围内的
数据,超出范围就不能更新了
(1)插入insert
和表的操作一样
(2)更新update
和表的操作一样
(3)删除delete
和表的操作一样
七、删除视图
删除视图是指删除数据库中已经存在的视图,删除视图时,只能删除视图的定义
不能删除数据
-- 语法格式
drop view [if exists] 视图名列表 [restrict | cascaded]