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

视图具有以下优点: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权限。

项目五总结:创建视图相关推荐

  1. 项目五总结 创建与使用视图

    .创建视图         视图中包含了SELECT查询的结果,因此视图的创建基于SELECT语句和已存在的数据表.视图可以建立在一张表上,也可以建立在多张表上.在MySQL中,创建视图使用CREAT ...

  2. Oracle笔记 五、创建表、约束、视图、索引、序列、同义词、表空间

    alter table userInfo add(msn varchar2(20)); 1.建表 create table userInfo ( id number(6), name varchar2 ...

  3. oracle视图如何创建索引,ORACLE 创建视图索引序列

    /* 视图View 视图是从若干基本表和(或)其他视图构造出来的表 视图存放的都是查询语句,并没有真实的数据 虚表 作用 限制对数据的操作 复杂查询变简单 提供相同数据的不同显示 UNION ALL ...

  4. 【Flutter】创建 Flutter 项目 ( Android Studio 创建并运行 Flutter 应用 | 命令行创建并运行 Flutter 应用 | 运行 Flutter 应用三种方式 )

    文章目录 一.Android Studio 中创建 Flutter 项目 二.命令行创建 Flutter 项目 三.通过命令行方式运行 Flutter 项目 四.通过 Android Studio 可 ...

  5. 后端技术:Java定时任务的五种创建方式

    Quartz表达式生成地址:http://cron.qqe2.com/ 支持生成定时任务表达式和反解析,使用Quartz表达式的定时任务如下 xxl-job springboot 的 @Schedul ...

  6. 《BI项目笔记》数据源视图设置

    原文:<BI项目笔记>数据源视图设置 目的 数据源视图是物理源数据库和分析维度与多维数据集之间的逻辑数据模型.在创建数据源视图时,需要在源数据库中指定包含创建维度和多维数据集所需要的数据表 ...

  7. couchbase_Couchbase 101:从Java应用程序创建视图(MapReduce)

    couchbase 使用Couchbase 2.0开发新应用程序时,有时需要从代码中动态创建视图. 例如,在安装应用程序,编写一些测试时,可能会需要此方法:或者,在构建框架时,您也可以使用此方法,并希 ...

  8. Couchbase 101:从Java应用程序创建视图(MapReduce)

    使用Couchbase 2.0开发新应用程序时,有时需要从代码中动态创建视图. 例如,在安装应用程序,编写一些测试时,可能会需要此方法:或者,在构建框架时,您也可以使用它,并希望动态创建视图以查询数据 ...

  9. Oracle视图添加约束,Oracle创建视图的语法

    Oracle创建视图的语法 导读:就爱阅读网友为大家分享了多篇关于 "oracle 创建序列语法" 资料,内容精辟独到,非常感谢网友的分享,希望从中能找到对您有所帮助的内容. 相关 ...

最新文章

  1. js RegExp用法
  2. Python学习笔记(十五):类基础
  3. LeetCode.917-只反转字母(Reverse Only Letters)
  4. hunnu---11547 你的组合数学学得如何?
  5. esxi安装openwrt_双软路由安装——ROS安装、上网、DNS缓存、常用设置(小白教程)...
  6. 直接拿来用,10个PHP代码片段(收藏)
  7. [剑指offer]面试题8:旋转数组的最小数字
  8. ROS下的多参数调用,boost::bind使用
  9. nor flash与nand flash启动的简单比较--APPLE的ARM学习笔记一
  10. Maven的打包命令
  11. macd是什么意思,详析MACD是什么意思
  12. 为什么mysql中不要用blob这种大字段
  13. 学习QT一周做的小游戏-钢琴块
  14. Gateway NV47H18C BIOS 密码清除
  15. 【微信小程序】二维数组列表渲染
  16. 1143-最长公共子序列的长度和最长公共子序列
  17. 智能电话机器人(AI语音机器人)是什么
  18. 基于Android的小说电子书阅读app
  19. 新大陆云平台app制作(史上最简单)
  20. 电镜三维重构中多构象的辨别方法

热门文章

  1. 九江性能优良戴尔服务器,戴尔服务器R410
  2. 【报告分享】美妆行业新国货品牌数字营销系列研究报告(附下载)
  3. 消防设备电源监控系统对老旧小区升级的意义
  4. 3种Python恶搞脚本,医院的WiFi实在太快了
  5. ️ 如何绕过 BKY 对 script 的屏蔽
  6. 时间序列定阶matlab,时间序模型判断及定阶
  7. 睿尔曼超轻量仿人机械臂--机械臂简介拖动示教
  8. 口腔ct重建服务器原理,基于口腔CT重建数据的牙齿分割与可视化研究
  9. 一个前端开发工程师的Vim跟IDE一样
  10. ARM + Linux + QT 智能停车收费系统