项目五总结:创建视图

2023-05-16

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

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


 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

项目五总结:创建视图 的相关文章

  • HTML制作个人名片

    题目 xff1a 完成以下效果图 xff0c 上传代码和效果图 xff08 具体样式提示如下 xff1a 整个大盒子尺寸为 150 278 效果图居中对齐 xff0c 左右外边距50px 字体 xff1a 楷体 xff1b 2 段落设置 x
  • 原码,反码,补码的概念

    计算机里都是以补码 的形式存储数据 xff0c 电脑只能识别二进制的0和1 xff0c 一个字节 xff08 8位 xff09 为例 原码 xff1a 最高位符号位 xff0c 0代表正数 xff0c 1代表负数 xff0c 非符号位为该数
  • cmake编译opencv开源项目报错问题

    最近使用cmake在编译一个配置了opencv环境的c 43 43 开源项目时遇到如下问题 CMake Warning at D opencv4 OpenCVConfig cmake 176 message Found OpenCV Win
  • 第一个SpringBoot项目的创建

    目录 一 SpringBoot是什么 xff1f 初识springboot springboot的优点 二 SpringBoot项目的创建与简单运行 x1f351 使用idea创建springboot项目 x1f351 Spring Boo
  • 解决在vue3中使用reactive响应式,赋值后造成页面不改变的问题?

    文章目录 场景原因一 例子二 解决方法1 使用ref存储响应式数据2 在reactive中使用对象包裹要改变的数据3 for of循环push到reactive数据中 xff0c 不破坏数据结构 总结 场景原因 我们需要在vue3中使用服务
  • ubuntu交叉编译工具arm-linux-gcc安装

    1 安装交叉编译工具 xff1a arm linux gcc 安装包4 4 6 TQ210 release 20120720 tar bz2 环境 xff1a ubuntu 20 版 xff0c 已换清华源 1 1解压文件 提取解压1 1
  • MYSQL(1)----初阶

    一 新增 insert into 表名 values 列的值 xff0c 列的值 xff0c 列的值 xff0c 列的值 insert into 表名 字段1 xff0c 字段2 values 列的值 xff0c 列的值 列的值 xff0c
  • GitLab -- 创建新用户

    登录GitLab xff0c 点击最上面的扳手图标 xff0c 进入 管理区域 页面 xff0c 点击 新建用户 进入新建用户页面 xff0c 输入对应信息 信息确认后 xff0c 点击 创建用户 用户创建成功后 xff0c 点击 编辑 按
  • debian技能大赛 笔记 (一)静态IP 网卡重启

    一 Debian静态IP 1 使用vim打开 etc network interfaces配置文件 vim etc network interfaces 2 在配置文件里添加 auto 网卡号 allow hotplug 网卡号 iface
  • Debian技能大赛笔记(二)service 、systemctl等命令消失不见解决办法

    二 service systemctl等命令消失不见解决办法 1 使用命令进入root模式 wt 64 Rserver su root Password root 64 Rserver home wt 2 使用vim 使用vi或者nano都
  • debian技能大赛笔记(八)创建DISK RAID5 自动挂载

    一 问题 1 在虚拟机上添加四个1g的硬盘 2 创建raid5 其中一个作为热备盘 设备名为 md0 3 将md0设置为LVM 设备名为md0 4 格式化为ext4 文件系统 5 开机自动挂载到 data目录 添加硬盘 添加完几个硬盘虚拟机
  • Debian大赛笔记(十)修改系统语言

    1 在root用户下输入 dpkg reconfigure locales 选择ZH CN xff08 简体中文 xff09 按空格键选择 xff0c 选择成功后重启系统语言便会修改成功
  • Debian技能大赛笔记(11)欢迎信息内容配置 删除欢迎信息

    技能大赛里都有一个差不多的题就是做一个欢迎信息 大致就像下图 那怎么配置呢 1 进入配置文件 vim etc update motd d 10 uname 在配置文件里加入 uname snrvm printf n printf 2s Ch
  • 上班摸鱼看小说的最佳软件

    这个软件几乎满足了我对上班摸鱼的所有担忧 xff0c 比如上班的时候打开网页看下说 xff0c 那太明显了 xff0c 不说摄像头 xff0c 后台看一下浏览器历史记录就暴露的特别明显 xff0c 这合适吗 xff1f 老板来到你身后远远的
  • iOS-UI-导航控制器-导航栏

    文章目录 导航控制器导航控制器的基本创建方法导航控制器的基本框架如下图所示添加单个按钮 x1f518 添加多个按钮 x1f518 创建按钮数组导航控制器效果 导航控制器的切换VcRoot界面切换事件函数 导航控制器 导航控制器 xff1a
  • 【iOS开发】-UIViewController加载过程和生命周期

    文章目录 前言ViewController执行过程的探讨ViewControllerOne 函数介绍顺序引入ViewControllerSecond引入 ViewControllerOne点击执行到ViewControllerSecond的
  • 【C语言】魔方阵的实现(最全)

    魔方阵的实现 xff08 最全 xff09 一 什么是魔方阵 xff1f 魔方矩阵 xff0c 又称幻方 xff0c 是具有相同的行数和列数 xff0c 并在每行每列 对角线上的和都相等的矩阵 N阶幻方 xff0c 即将自然数1到排成N行N
  • 四种求最大公约数的算法 C / C++

    文章目录 前言一 辗转相除法1 算法简介2 算法描述3 代码及复杂度 二 穷举法 xff08 枚举法 xff09 1 算法简介2 算法描述3 代码及复杂度 三 更相减损法1 算法简介2 算法描述3 代码及复杂度 四 Stein算法 xff0
  • 安装使用supervisor来启动服务

    supervisor 使用方法 supervisor 官网 是一个unix的系统进程管理软件 xff0c 可以用它来管理apache nginx等服务 xff0c 若服务挂了可以让它们自动重启 当然也可以用来实现golang的守护进程 学完
  • 超详细讲解实现拓扑排序、关键路径

    今天 xff0c 小编带着大家来学习图中非常重要的一环 xff0c 拓扑排序和关键路径 xff01 目录 一 绪论 实际应用 二 拓扑排序 xff08 一 xff09 含义 xff08 二 xff09 实现原理 xff08 三 xff09

随机推荐

  • getline函数介绍

    今天 xff0c 小编将为大家讲解有关getline函数的相关知识 目录 一 cin getline char s streamsize n char delim 二 getline istream amp is string amp st
  • C++语法——详解运算符重载

    运算符重载是C 43 43 的一个重要特性 有了运算符重载 xff0c 在代码编写时能更好的实现封装 目录 一 运算符重载介绍 二 运算符重载形式 xff08 一 xff09 参数 xff08 二 xff09 返回值 xff08 三 xff
  • linux—常用gdb调试命令汇总

    目录 一 准备工作 二 调试命令 xff08 一 xff09 查看代码内容 xff08 l xff08 二 xff09 开始调试 xff08 r xff09 xff08 三 xff09 查看当前调试位置 xff08 where xff09
  • Linux——详细模拟实现shell(进程控制综合运用)

    在运行linux时 xff0c 我们总免不了需要输入各种指令让shell进行解析 xff0c 从而与系统进行交互 那么我们有没有可能自己自制一个简易的shell呢 xff1f 答案是当然没问题 目录 一 大体思路 二 具体实现 xff08
  • C++语法——详解虚继承

    目录 一 什么是虚继承 二 虚继承原理 三 虚继承使用注意事项 一 什么是虚继承 所谓虚继承 xff08 virtual xff09 就是子类中只有一份间接父类的数据 该技术用于解决多继承中的父类为非虚基类时出现的数据冗余问题 xff0c
  • Qt——基本介绍、详解对象树

    目录 一 基本介绍 二 对象树 一 基本介绍 创建qt项目是 xff0c 如果选择空窗口QWidget xff0c 那么mian函数中会有如下代码 xff1a include 34 myWindow h 34 include lt QApp
  • 项目:手把手实现高并发内存池

    一 前言 xff08 一 xff09 项目简介 高并发内存池 xff08 ConCurrentMemoryPool xff09 xff0c 其原型是google的开源项目tcmalloc 全称是t hread c ache malloc x
  • Linux——TCP协议与相关套接字编程

    一 TCP协议概念 与UDP协议相同 xff0c TCP协议也是应用在传输层 的协议 虽然都是应用在传输层 xff0c 但是使用方式和应用场景上大不一样 TCP协议具有 xff1a 有连接 xff08 可靠 xff09 面向字节流的特点 x
  • C++ Primer笔记——排列算法(next_permutation、prev_permutation、is_permutation)

    目录 概述 next permutation prev permutation is permutation 概述 页数 xff1a P778 xff08 A 2 7 排列算法 xff09 头文件 xff1a lt algorithm gt
  • Ubuntu更改JupyterLab的工作目录

    1 第一步 jph 64 jph opt anaconda3 jupyter lab generate config Writing default config to home jph jupyter jupyter lab config
  • 项目5 创建与使用视图

    1 简单化 视图不仅可以简化用户对数据的理解 xff0c 也可以简化对数据的操作 那些被经常使用的查询定义为视图 xff0c 从而使用户在以后的操作中不必每次都指定全部的条件 2 安全性 通过视图用户只能查询和修改他们所能见到的数据 xff
  • 第五章习题(1)

    int main int k x for k 61 0 x 61 0 k lt 61 9 amp amp x 61 10 k 43 43 x 61 x 43 2 printf 34 d d 34 k x return 0 习题2 int m
  • 数据库表的约束

    单字段主键 create table表名 字段名1数据类型1comment 34 备注信息1 34 primary key 字段名2数据类型2comment 34 备注信息2 34 create table teacher no varch
  • 数据库第三次作业

    如下表新增数据 xff1a 教师表 teacher 指定字段插入数据 教师号 教师姓名 职称 工资 岗位津贴 T1 Anne Professor 5000 2000 T2 Adam 2000 T3 Alan Associate Profes
  • 数据库第七次作业

    更新教师表中所有记录 xff0c 将津贴改为2000 更新教师表中教师号在T5到T8之间的记录 xff0c 将津贴改为1500 更新授课表中周数为8的记录 xff0c 将教师号改为T7 xff0c 课程号改为C1 更新课程表中课时数不在45
  • 第六章总结(创建与使用存储过程)

    一 MySQL的存储过程 xff08 1 存储过程是一组为了完成特定功能的SQL语句块 xff0c 经编译后存储在数据库中 xff0c 用户通过指定存储过程的名称并给定参数 xff08 如果该存储过程带有参数 xff09 来调用并执行它 x
  • 第七章总结(创建与使用触发器)

    定义 xff1a 触发器是特殊的存储过程 xff0c 是一个被指定关联到数据表上的数据库对象 xff0c 可以看作数据表定义的一部分 xff0c 可用于实现数据库中数据的完整性 普通的存储过程通过Call命令调用 xff0c 而触发器的调用
  • 第八章总结(数据库的安全性维护)

    insert语句创建用户 insert into user hostuser passwordssl cipherx509 issuer x509 subject values 34 主机号 34 xff0c 34 用户名 34 xff0c
  • 输入10个数字,找出其中的最大值,最小值,并输出。

    include lt stdio h gt main int i float max min a printf 请输入10个数字 scanf 34 f 34 amp a max 61 min 61 a for i 61 1 i lt 61
  • 项目五总结:创建视图

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