使用视图方式操作MySQL数据表

2024-09-07 05:52

本文主要是介绍使用视图方式操作MySQL数据表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

7.1  认识视图

7.1.1  视图的含义

视图是一种常用的数据库对象,可以把它看成从一个或几个源表导出的虚表或存储在数据库中的查询,对视图所引用的源表来说,视图的作用类似于筛选。

视图一经定义后,就可以像源表一样被查询、修改和删除。视图为查看和存取数据提供了另外一种途径,使用查询可以完成的大多数操作,使用视图一样可以完成。

使用视图还可以简化数据操作。当通过视图修改数据时,相应源表的数据也会发生变化 ;同时,若源表的数据发生变化,则这种变化也可以自动地同步反映到视图中。

视图是在源表或者视图基础上重新定义的虚拟表,它可以从源表中选取用户所需的数据,那些对用户没有用或者用户没有权限了解的数据,都可以屏蔽掉。

7.2  创建视图

创建视图可以使用 Create View 语句,该语句完整的语法格式如下 :

Create

            [ Or Replace ]

            [ < 算法选项 > ]

            [ < 视图定义者 > ]

            [ < 安全性选项 > ]

View < 视图名 > [ < 视图的字段名称列表 > ]

As <Select 语句 >

            [ 检查选项 ]

说明

7.3  查看视图的相关信息

1.使用 Describe 语句查看视图的结构定义

如果只需要了解视图的各个字段的简单信息,可以使用 Describe 语句,其语法格式与查询数据表一样。通常情况下,可以使用缩写 Desc 代替 Describe

Describe < 视图名称 > ;

2.使用 Show Table Status 语句查看视图的基本信息

MySQL 中,可以使用 Show Table Status 语句查看视图的基本信息,其语法格式如下 :

Show Table Status Like < 视图名称 >

该语句执行结果中列“Comment”的值为“VIEW”,表示视图,其他列为 NULL(说明这是一个虚表)。

3.使用 Show Create View 语句查看视图的定义信息

MySQL 中,可以使用 Show Create View 语句查看视图的定义信息,其语法格式如下 :

Show Create View < 视图名称 > ;

任务 7-1】使用 Create View 语句创建单源表视图

任务描述

创建一个名称为“view_ 人邮社 0701”的视图,该视图包括“人民邮电出版社”出版的所有价格大于 40 元的图书的信息,视图中包括数据表“图书信息”中的商品编号、图书名称、出版社、商品类型等数据,已知“人民邮电出版社”的字段“出版社 ID”的值为 1

任务实施

任务 7-2】使用 Navicat for MySQL 创建多源表视图

任务描述

创建一个名称为“view_ 人邮社 0702”的视图,该视图包括“人民邮电出版社”出版的所有图书的信息,视图中包括数据表“图书信息”中的商品编号、图书名称、数据表“出版社信息”中的出版社名称、数据表“商品类型”中的类型名称等数据。

任务实施

视图创建工具窗口中单击构建按钮,关闭该窗口返回 Navicat for MySQL 的“视图”定义区域。设置好字段、数据表及关联条件、Where 条件的查询语句如下所示 :

任务 7-3】修改视图

当视图不符合使用需求时,可以使用 Alter View 语句对其进行修改,视图的修改方法与创建方法相似,其语法格式如下 :

Alter

          [ < 算法选项 > ]

          [ < 视图定义者 > ]

          [ < 安全性选项 > ]

View < 视图名 >

As <Select 语句 >

          [ 检查选项 ]

任务描述

1)修改视图“view_ 人邮社 0701”,使该视图包括“人民邮电出版社”出版的价格高于 40 元的所有图书信息,视图中包括数据表“图书信息”中的商品编号、图书名称、价格、出版社、商品类型等数据。

2)修改视图“view_ 人邮社 0702”,使该视图包括“人民邮电出版社”出版的价格高于 40 元的所有图书信息,视图中包括数据表“图书信息”中的商品编号、图书名称、数据表“出版社信息”中的出版社名称、数据表“商品类型”中的类型名称等数据。

任务实施

任务 7-4】利用视图查询与更新数据表中的数据

任务描述

1)创建一个名称为“view_ 用户注册 0703”的视图,该视图包括所有的用户注册信息。

2)利用视图“view_ 用户注册 0703”查询“权限等级”为“C”的用户注册信息。

3)利用视图“view_ 用户注册 0703”新增一个注册用户,用户 ID 为“7”,用户编号为“u00007”,用户名称为“测试用户”,密码为“todayBetter,权限等级为“A”,手机号码为“18074198678”,用户类型为“2”

4)使用视图“view_ 用户注册 0703”修改前一步新注册的用户,将其权限等级修改为“C”,用户类型修改为“1”

5)使用视图“view_ 用户注册 0703”删除前面新注册的用户“测试用户”。

任务实施

任务 7-5】删除视图

删除视图是指删除数据库中已存在的视图,删除视图时,只能删除视图的定义,不会删除源表的数据。在 MySQL 中,使用 Drop View 语句删除视图时,用户必须拥有 Drop 权限。

删除视图的语法格式如下 :

这篇关于使用视图方式操作MySQL数据表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144236

相关文章

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

C# 读写ini文件操作实现

《C#读写ini文件操作实现》本文主要介绍了C#读写ini文件操作实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、INI文件结构二、读取INI文件中的数据在C#应用程序中,常将INI文件作为配置文件,用于存储应用程序的

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ