项目5总结:创建与使用视图

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 项目5总结:创建与使用视图

       视图是一个从或多个表中导出来的表,它是一种虚拟存在的表,并且表的结构和数据都依赖于基本表,通过视图不仅可以看到存放在基本表中的数据,还可以像操作基本表一样,对视图中存放的数据进行查询、修改和删除。


视图具有以下优点:1、简单化 2、安全性 3、逻辑数据独立性

【任务5.1】使用语句创建视图

1.创建视图

       视图中包含了SELECT查询的结果,因此视图的创建基于SELECT语句和已存在的数据表。视图可以建立在一张表上,也可以建立在多张表上。在MySQL中,创建视图使用CREATE VIEW语句,其基本语法格式为:

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

在上述语法格式中,每个部分的含义如下。


CREATE:表示创建视图的关键字,上述语句能创建新的视图。


OR REPLACE:如果给定了此子句,表示该语句可以替换已有视图。


ALGORITHM:可选项,表示视图选择的算法。


UNDEFINED:表示MySQL将自动选择所要使用的算法。


MERGE:表示将使用视图的语句与视图定义合并起来,使得视图定义的某一部分取代语句的对应部分。


TEMPTABLE:表示将视图的结果存入临时表,然后使用临时表执行语句。


view_name:表示要创建的视图名称。


column_list:可选项,表示字段名清单。指定了视图中各个字段名,默认情况下,与SELECT 语句中查询的字段名相同。


AS:表示指定视图要执行的操作。


select_statement:一个完整的查询语句,表示从某个表或视图中查出某些满足条件的记录,将这些记录导入视图中。


WITH CHECK OPTION:可选项,表示创建视图时要保证在该视图的权限范围之内。


CASCADED:可选项,表示创建视图时,需要满足与该视图有关的所有相关视图和表的条件,该参数为默认值。


LOCAL:可选项,表示创建视图时,只要满足该视图本身定义的条件即可。该语句要求具有针对视图的CREATE VIEW 权限,以及针对由SELECT语句选择的每一列上的某些权限。对于在SELECT语句中其他地方使用的列,必须具有SELECT权限。


如果还有OR REPLACE子句,必须在视图上具有DROP权限。视图属于数据库。在默认情况下,将在当前数据库创建新视图。要想在给定数据库中明确创建视图,创建时应将名称指定为db_name.view_name。

2.视图的规则和限制

创建视图前,应该知道它的一些限制。视图创建和使用最常见的规则和限制如下。


①与表一样,视图必须唯一命名(不能给视图取与别的视图或表相同的名称)。


②对于可以创建的视图数目没有限制。


③为了创建视图,必须具有足够的访问权限。这些限制通常由数据库管理人员授予。

④视图可以嵌套,即可以利用从其他视图中检索数据的查询来构造一个视图。


⑤ORDER BY可以用在视图中,但如果在该视图检索数据 SELECT中也含有ORDER BY,那么该视图中的ORDER BY将被覆盖。

⑥视图不能索引,也不能有关联的触发器或默认值。


⑦视图可以和表一起使用。例如,编写一条连接表和视图的SELECT语句。

【任务5.2】修改视图

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

1.使用 CREATE OR REPLACE VIEW 语句修改视图

在MySQL中,使用CREATE OR REPLACE VIEW语句修改视图,其语法格式为:

CREATE [OR REPLACE] [ALGORITHM={UNDEFINEDTEMPTABLE} ]
VIEW view_name [ (column_list) ]
AS select_statement
[WITH [CASCADED|LOCAL] CHECK OPTION]

可以看到,修改视图的语句和创建视图的语句是完全一样的。如果视图已经存在,那么使用修改语句对视图进行修改;如果视图不存在,那么将创建一个新视图。

2.使用ALTER 语句修改视图

ALTER语句是MySQL提供的另外一种修改视图的方法,其修改视图的语法格式为:

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

这个语法中的关键字与前面创建视图的关键字是一样的,这里不再介绍。

【任务5.3】利用视图更新数据表

更新视图是指通过视图来插入、更新、删除表中的数据,因为视图是一个虚拟表,其中没有数据。当通过视图更新数据时,其实是在更新基本表中的数据,如果对视图增加或删除记录,实际上是对其基本表增加或删除记录。视图更新主要有3种方法:UPDATE、INSERT和DELETE。

1.使用UPDATE 语句更新视图

在MySQL中,可以使用UPDATE语句对视图中原有的数据进行更新。

2.使用INSERT 语句更新视图

在MySQL中,可以使用INSERT语句对视图中的基本表插入一条记录。

3.使用DELETE 语句更新视图

在MySQL中,可以使用DELETE语句对视图中的基本表删除部分记录。


需要注意的是,尽管更新视图有多种方式,但并非所有情况下都能执行视图的更新操作。当视图中包含如下内容时,视图的更新操作将不能被执行。


(1)视图中不包含基本表中被定义为非空的列。


(2)在定义视图的SELECT语句后的字段列表中使用了数学表达式。


(3)在定义视图的SELECT语句后的字段列表中使用了聚合函数。


(4)在定义视图的SELECT 语句中使用了 DISTINCT、UNION、LIMIT、GROUP BY或 HAVING子句。

【任务5.4】删除视图

当视图不再需要时,可以将其删除,删除视图时,只会删除视图的定义,不会删除数据。删除一个或多个视图可以使用DROP VIEW语句,其基本语法格式为:

DROP VIEW [IF EXISTS]
view_name [,view_name]···
{RESTRICT | CASCADE}

其中,“view_name”是要删除的视图名称,可以添加多个需要删除的视图名称,各个名称之间使用逗号分隔开。删除视图必须拥有DROP权限。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
9月前
ArcGIS:如何新建图层组并添加数据、切换数据视图和布局视图、修改符号系统?
ArcGIS:如何新建图层组并添加数据、切换数据视图和布局视图、修改符号系统?
141 0
ArcGIS:如何新建图层组并添加数据、切换数据视图和布局视图、修改符号系统?
|
11月前
|
编解码 Android开发
视图 总结 基础
DragViewTaskRelease 使用FrameLayout布局(可以用其他的),内嵌imageView实现悬浮拖动和点击事件,继承View的ontouchEvent进行动作监听和移动 getX(),getY()等方法的区别(图解) BarPercentView 条形进度条(可设置 线性渐变-背景色-进度条颜色-进度条高度) 游戏下载进度条显示 zidingyiView矩形进度框,在构造函数里定义基础属性,初始化布局,定义俩个矩形,onMeasure获取宽高和onDraw方法显示
Revit 二次开发—通过视图名激活对应视图
Revit 二次开发—通过视图名激活对应视图
|
C语言 Perl
博途软件的基本操作,快捷操作有哪些?什么是博途视图和项目视图?
博途软件开发之初就把直观、高效、可靠作为非常重要的关键因素,持续走访了世界多数国家的工程师并着眼未来,博途软件在界面设置、窗口规划布局等多方面进行优化布置。如何快速了解博途软件的界面、操作规则是提高效率的关键环节。本节我们主要来介绍博途软件的基本操作。
博途软件的基本操作,快捷操作有哪些?什么是博途视图和项目视图?
|
SQL 数据处理
视图的创建
如何创建和使用视图的功能,更好的方便我们的工作。
76 0
|
监控 中间件 程序员
关于开发视图
开发视图是逻辑视图的实现,它又叫实现视图,描述了在开发环境中软件的静态组织结构,主要侧重于软件模块的组织和管理。
645 0
关于开发视图
|
Java Android开发
【JetPack】为现有 Android 项目配置视图绑定 ( ViewBinding ) 模块 ( 视图绑定不影响传统布局操作 | 视图绑定类关联 Activity | 视图绑定类本质 )(一)
【JetPack】为现有 Android 项目配置视图绑定 ( ViewBinding ) 模块 ( 视图绑定不影响传统布局操作 | 视图绑定类关联 Activity | 视图绑定类本质 )(一)
179 0
【JetPack】为现有 Android 项目配置视图绑定 ( ViewBinding ) 模块 ( 视图绑定不影响传统布局操作 | 视图绑定类关联 Activity | 视图绑定类本质 )(一)
|
Android开发
【JetPack】为现有 Android 项目配置视图绑定 ( ViewBinding ) 模块 ( 视图绑定不影响传统布局操作 | 视图绑定类关联 Activity | 视图绑定类本质 )(二)
【JetPack】为现有 Android 项目配置视图绑定 ( ViewBinding ) 模块 ( 视图绑定不影响传统布局操作 | 视图绑定类关联 Activity | 视图绑定类本质 )(二)
160 0
|
存储 数据库
OushuDB 创建和管理视图
视图(View)是从一个或多个表(或视图)导出的表。视图与表(有时为与视图区别,也称表为基本表——Base Table)不同,视图是一个虚表,即视图所对应的数据不进行实际存储,数据库中只存储视图的定义,在对视图的数据进行操作时,系统根据视图的定义去操作与视图相关联的基本表。
86 0
OushuDB 创建和管理视图
|
XML 数据格式
数据视图
原文:数据视图 1、数据视图。 使用数据视图,可添加导航逻辑并实现过滤、排序和分组。 2、View对象。 当将结合(或DataTable)绑定到ItemsControl控件时,会不加通告地在后台创建数据视图---位于数据源和绑定的控件之间。
940 0