MySQL视图

🙉 作者简介: 全栈领域新星创作者 ;天天被业务折腾得死去活来的同时依然保有对各项技术热忱的追求,把分享变成一种习惯,再小的帆也能远航。

🏡 个人主页: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]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员晓凡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值