百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL视图的基本操作

wptr33 2024-11-26 09:29 33 浏览

原文地址:https://dwz.cn/B5nmwY6Y

作者:best.lei

视图是数据库中的虚拟表。包含一系列带有名称的行和列数据。视图是从一个或者多个表中导出的,视图的行为与表非常相似,用户可以使用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表中查看视图详细信息。

  1. DESCRIBE语句查看视图基本信息,语法为:DESCRIBE view_name; 查看view_s_class视图如上上图所示。结果显示视图的字段定义、字段数据类型、是否为空、是否为主外键、默认值和额外信息。
  2. SHOW TABLE STATUS语句查看视图基本信息,语法为:SHOW TABLE STATUS LIKE 'view_name'; 如下图所示,查看view_s_class视图,结果显示,表的说明Comment的值为VIEW说明该表为视图,其他信息为NULL说明这是一个虚表。当查询学生表时,信息包含了存储引擎、创建时间等,Comment信息为空,这就是视图和表的区别。


  1. SHOW CREATE VIEW语句查看视图详细信息,语法为:SHOW CREATE VIEW 'view_name'; 该语句查看视图的详细定义,结果显示视图的名称、创建数据的语句等信息。
  1. 在视图表中查看详细信息,利用SELECT语句查询information_schema数据库下的views表中存储所有视图的定义。查询语句为:SELECT * FROM information_shcema.views;
  • 修改视图

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

  1. 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进行修改。
  1. 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。

  1. INSERT语句向视图中插入数据,代码为:INSERT INTO view_student value(10,'赵云','Hebei');
  1. UPDATA语句更新视图中的数据,代码为:UPDATE view_student SET sAddress='Anhui' WHERE sID=8;
  1. 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中视图和表的区别和联系
  • 两者的区别

  1. 视图是编译好的SQL语句,是基于SQL语句的结果集的可视化的表;
  2. 视图没有实际的物理记录,而基本表有;
  3. 表是内容,视图是窗口;
  4. 表占用物理空间而视图不占用物理空间,视图只是逻辑概念的存在;
  5. 视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些SQL语句的集合。从安全的角度说,视图可以防止用户接触数据表。
  6. 表属于全局模式中的表,是实表;视图属于局部模式,是虚表;
  7. 视图的建立和删除只影响视图本身,但不影响对应的基本表。
  • 两者的联系
  1. 视图是在基本表之上建立的表,视图的结构和内容都来自基本表,依赖基本表存在而存在。一个视图可以对应一到多个基本表,是基本表的抽象和在逻辑意义上建立的新关系。

相关推荐

redis的八种使用场景

前言:redis是我们工作开发中,经常要打交道的,下面对redis的使用场景做总结介绍也是对redis举报的功能做梳理。缓存Redis最常见的用途是作为缓存,用于加速应用程序的响应速度。...

基于Redis的3种分布式ID生成策略

在分布式系统设计中,全局唯一ID是一个基础而关键的组件。随着业务规模扩大和系统架构向微服务演进,传统的单机自增ID已无法满足需求。高并发、高可用的分布式ID生成方案成为构建可靠分布式系统的必要条件。R...

基于OpenWrt系统路由器的模式切换与网页设计

摘要:目前商用WiFi路由器已应用到多个领域,商家通过给用户提供一个稳定免费WiFi热点达到吸引客户、提升服务的目标。传统路由器自带的Luci界面提供了工厂模式的Web界面,用户可通过该界面配置路...

这篇文章教你看明白 nginx-ingress 控制器

主机nginx一般nginx做主机反向代理(网关)有以下配置...

如何用redis实现注册中心

一句话总结使用Redis实现注册中心:服务注册...

爱可可老师24小时热门分享(2020.5.10)

No1.看自己以前写的代码是种什么体验?No2.DooM-chip!国外网友SylvainLefebvre自制的无CPU、无操作码、无指令计数器...No3.我认为CS学位可以更好,如...

Apportable:拯救程序员,IOS一秒变安卓

摘要:还在为了跨平台使用cocos2d-x吗,拯救objc程序员的奇葩来了,ApportableSDK:FreeAndroidsupportforcocos2d-iPhone。App...

JAVA实现超买超卖方案汇总,那个最适合你,一篇文章彻底讲透

以下是几种Java实现超买超卖问题的核心解决方案及代码示例,针对高并发场景下的库存扣减问题:方案一:Redis原子操作+Lua脚本(推荐)//使用Redis+Lua保证原子性publicbo...

3月26日更新 快速施法自动施法可独立设置

2016年3月26日DOTA2有一个79.6MB的更新主要是针对自动施法和快速施法的调整本来内容不多不少朋友都有自动施法和快速施法的困扰英文更新日志一些视觉BUG修复就不翻译了主要翻译自动施...

Redis 是如何提供服务的

在刚刚接触Redis的时候,最想要知道的是一个’setnameJhon’命令到达Redis服务器的时候,它是如何返回’OK’的?里面命令处理的流程如何,具体细节怎么样?你一定有问过自己...

lua _G、_VERSION使用

到这里我们已经把lua基础库中的函数介绍完了,除了函数外基础库中还有两个常量,一个是_G,另一个是_VERSION。_G是基础库本身,指向自己,这个变量很有意思,可以无限引用自己,最后得到的还是自己,...

China's top diplomat to chair third China-Pacific Island countries foreign ministers' meeting

BEIJING,May21(Xinhua)--ChineseForeignMinisterWangYi,alsoamemberofthePoliticalBureau...

移动工作交流工具Lua推出Insights数据分析产品

Lua是一个适用于各种职业人士的移动交流平台,它在今天推出了一项叫做Insights的全新功能。Insights是一个数据平台,客户可以在上面实时看到员工之间的交流情况,并分析这些情况对公司发展的影响...

Redis 7新武器:用Redis Stack实现向量搜索的极限压测

当传统关系型数据库还在为向量相似度搜索的性能挣扎时,Redis7的RedisStack...

Nginx/OpenResty详解,Nginx Lua编程,重定向与内部子请求

重定向与内部子请求Nginx的rewrite指令不仅可以在Nginx内部的server、location之间进行跳转,还可以进行外部链接的重定向。通过ngx_lua模块的Lua函数除了能实现Nginx...