MySQL中数据视图操作详解

目录
  • 1.视图概述
    • 1.1创建视图
    • 1.2视图的查询
  • 2.操作视图
    • 2.1通过视图操作数据
    • 2.2修改视图定义
    • 2.3删除视图

1.视图概述

视图是从一个或多个表(或视图)导出的表。视图与表(有时为与视图区别,也称表为基本表)不同,视图是一个虚表,即视图所对应的数据不进行实际存储,数据库中只存储视图的定义,对视图的数据进行操作时,系统根据视图的定义去操作与视图相关联的基本表。

视图一经定义,就可以像表一样被查询、修改、删除和更新。使用视图有下列优点:

1、为用户集中数据,简化用户的数据查询和处理。有时用户所需要的数据分散在多个表中,定义视图可将它们集中在一起,从而方便用户的数据查询和处理。

2、屏蔽数据库的复杂性。用户不必了解复杂的数据库中的表结构,并且数据库表的更改也不影响用户对数据库的使用。

3、简化用户权限的管理。只须授予用户使用视图的权限,而不必指定用户只能使用表的特定列,也增加了安全性。

4、便于数据共享。各用户不必都定义和存储自己所需的数据,可共享数据库的数据,这样同样的数据只需存储一次。

5、可以重新组织数据以便输出到其他应用程序中。

使用视图时,要注意下列事项:

1、 在默认情况下,将在当前数据库创建新视图。要想在给定数据库中明确创建视图,创建时应将名称指定为db_name.view_name

2、视图的命名必须遵循标志符命名规则,不能与表同名,且对每个用户视图名必须是唯一的,即对不同用户,即使是定义相同的视图,也必须使用不同的名字。

3、不能把规则、默认值或触发器与视图相关联

4、不能在视图上建立任何索引,包括全文索引

5、视图中使用SELECT语句有以下的限制:

5.1、定义视图的用户必须对所参照的表或视图有查询(即可执行SELECT语句)的权限,在定义中引用的表或视图必须存在

5.2、不能包含FROM子句中的子查询,不能引用系统或用户变量,不能引用预处理语句参数

5.3、在视图定义中允许使用ORDER BY子句,但是,如果从特定视图进行了选择,而该视图使用了具有自己ORDER BY的语句,则视图定义中的ORDER BY将被忽略。

1.1创建视图

视图的创建语法格式:

CREATE [ OR REPLACE ] VIEW 视图名 [ ( 列名列表 ) ]
AS SELECT 语句
[ WITH [ CASCADED | LOCAL ] CHECK OPTION ]

例:创建Bookstore数据库上的jsj_sell视图,包括计算机类图书销售的订单号、图书编号、书名等情况。其中要保证对该视图的订单修改都要符合计算机类这个条件

CREATE OR REPLACE VIEW jsj_sell
AS
SELECT 订单号,Sell.图书编号,书名
FROM Book,Sell
WHERE Book.图书编号=Sell.图书编号
AND Book.图书类别='计算机'
WITH CHECK OPTION;

例:创建Bookstore数据库中计算机类图书销售视图sale_avg,包括书名(在视图中列名为name)和该图书的平均订购册数(在视图中列名为sale_avg)

CREATE VIEW sale_avg(name,sale_avg)
AS
SELECT 书名,avg(订购册数)
FROM jsj_sell
GROUP BY 书名;

上面创建了计算机类图书销售视图jsj_sell,可以直接从jsj_sell视图中查询信息生成新视图。

1.2视图的查询

视图定义后,就可以像查询基本表那样对视图进行查询

例:在视图jsj_sell中查找计算机类图书的订单号和订购册数

SELECT 订单号,订购册数
FROM jsj_sell;

例:查找平均订购册数大于5本的订购客户的身份证号和平均订购册数

1、创建客户平均订购视图kh_avg,包括客户身份证号和平均订购册数

CREATE VIEW kh_avg(sfz,order_avg)
AS
SELECT 身份证号,AVG(订购册数)
FROM Sell
GROUP BY 身份证号;

2、对kh_avg视图进行查询

SELECT *
FROM kh_avg
WHERE order_avg>5;

注意:使用视图查询时,若其关联的基本表中添加了新字段,则该视图将不包含新字段。如果与视图相关联的表或视图被删除,则该视图将不能再使用。

2.操作视图

2.1通过视图操作数据

2.1.1可更新视图

要通过视图更新基本表数据,必须保证视图是可更新视图,即可以在INSET、UPDATE或DELETE等语句中使用它们。对于可更新的视图,在视图中的行和基表中的行之间必须具有一对一的关系。有一些特定的其他结构,这类结构会使得视图不可更新。若视图包含以下结构中的任何一种,其就是不可更新的:

1、聚合函数

2、DISTINCT关键字

3、GROUP BY子句

4、ORDER BY子句

5、HAVING子句

6、UNION运算符

7、位于选择列表中的子查询

8、FROM子句中包含多个表

9、SELECT语句中引用了不可更新视图

10、WHERE子句中的子查询,引用FROM子句中的表

MySQL在多表上创建视图方法

2.1.2插入数据

当使用视图插入数据时,如果在创建视图时加上WITH CHECK OPTION子句,WITH CHECK OPTION子句会在更新数据时检查新数据是否符合视图定义中WHERE子句的条件。

WITH CHECK OPTION子句只能和可更新视图一起使用。

例:创建视图jsj_book,视图中包含计算机类图书的信息,并向jsj_book视图中插入一条记录:('IS-01','计算机','计算机基础')

1、创建视图jsj_book

CREATE OR REPLACE VIEW jsj_book
AS
SELECT *
FROM Book
WHERE 图书类别='计算机'
WITH CHECK OPTION;

2、插入记录

INSERT INTO jsj_book
VALUES('IS-01','计算机','计算机基础');

当视图所依赖的基本表有多个时,不能向该视图插入数据,因为这将会影响多个基本表。

对INSERT语句还有一个限制:SELECT语句中必须包含FROM子句中指定表的所有不能为空的列。例如,若jsj_book视图定义时不加上“书名”字段,则插入数据时会出错。

2.1.3修改数据

使用UPDATE语句可以实现通过视图修改基本表数据。

例:将jsj_sell视图中的图书编号为IS-01的书名改为“MySQL基础”

UPDATE jsj_sell
SET 书名='MySQL基础'
WHERE 图书编号='IS-01';

2.1.4删除数据

如果视图来源于单个基本表,可以使用DELETE语句通过视图来删除基本表数据,对于依赖多个基本表的视图,不能使用DELETE语句。

例:删除jsj_book中“中国青年出版社”的记录

DELETE FROM jsj_book
WHERE 出版社='中国青年出版社';

2.2修改视图定义

可以使用ALTER VIEW语句对已有视图的定义进行修改

语法格式:

ALTER VIEW 视图名[ ( 列名列表 ) ]
AS select语句
[ WITH [ CASCADED | LOCAL ] CHECK OPTION ]

例:将jsj_book视图修改为只包含计算机类图书的图书编号、书名和单价

ALTER VIEW jsj_book
AS
SELECT 图书编号,书名,单价
FROM Book
WHERE 图书类别='计算机';

2.3删除视图

语法格式:DROP VIEW [ IF EXISTS ] 视图名1 [, 视图名2 ]...

若声明了IF EXISTS,则视图不存在的话也不会报错。使用DROP VIEW 一次可以删除多个视图。例:一次性删除jsj_book和jsj_sell

DROP VIEW jsj_book,jsj_sell;

到此这篇关于MySQL中数据视图操作详解的文章就介绍到这了,更多相关MySQL数据视图内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • MySQL初级入门篇之视图的相关概念及应用实例

    目录 1.浅谈数据库对象 2.什么是视图? 3.视图操作相关SQL 4.视图实操SQL 5.视图的优缺点 总结 1.浅谈数据库对象 2.什么是视图? 视图一方面可以帮我们使用表的一部分而不是所有的表,另一方面也可以针对不同的用户制定不同的查询视图.比如,针对一个公司的销售人员,我们只想给他看部分数据,而某些特殊的数据,比如采购的 价格,则不会提供给他.再比如,人员薪酬是个敏感的字段,那么只给某个级别以上的人员开放,其他 人的查询视图中则不提供这个字段.视图是一种 虚拟表 ,本身是 不具有数据 的

  • mysql视图之管理视图实例详解【增删改查操作】

    本文实例讲述了mysql视图之管理视图操作.分享给大家供大家参考,具体如下: mysql提供了用于显示视图定义的SHOW CREATE VIEW语句,我们来看下语法结构: SHOW CREATE VIEW [database_name].[view_ name]; 要显示视图的定义,需要在SHOW CREATE VIEW子句之后指定视图的名称,我们先来根据employees表创建一个简单的视图用来显示公司组织结构,完事在进行演示: CREATE VIEW organization AS SELE

  • MySQL数据库数据视图

    目录 一. 数据视图 二.数据视图操作 创建视图 修改视图数据 修改视图列明 删除视图 三.数据的备份与回复 liunx备份 mysql备份 四. MySQL存储过程和函数 概念 五.存储过程操作 初始数据 创建过程 调用存储过程 查找存储过程 删除存储过程 其他语法 六. 存储函数 一. 数据视图 视图是原始数据库数据的一种变换,是查看表中数据的另外一种方式.我们可以将视图看成是一个移动的窗口,从这个窗口中可以看到感兴趣的数据. 二.数据视图操作 创建视图 // 标准语法: CREATE VI

  • MySQL视图简介及基本操作教程

    前言 视图是数据库系统中一种非常有用的数据库对象.MySQL 5.0 之后的版本添加了对视图的支持. 认识视图 视图是一个虚拟表,其内容由查询定义.同真实表一样,视图包含一系列带有名称的列和行数据,但视图并不是数据库真实存储的数据表. 视图是从一个.多个表或者视图中导出的表,包含一系列带有名称的数据列和若干条数据行. 视图并不同于数据表,它们的区别在于以下几点: 视图不是数据库中真实的表,而是一张虚拟表,其结构和数据是建立在对数据中真实表的查询基础上的. 存储在数据库中的查询操作 SQL 语句定

  • MySQL视图原理与基本操作示例

    本文实例讲述了MySQL视图原理与基本操作.分享给大家供大家参考,具体如下: 概述 视图是一个虚拟表,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据.但是视图并不在数据库中以存储的数据值集形式存在.行和列数据来自由定义视图的查询所引用的表,并在引用视图时动态生成. 对其中所引用的基础表来说,视图的作用类似于筛选. 基本操作 建立视图 CREATE VIEW view_test(qty,price,total) AS SELECT quantity,price,quantit

  • MySQL 视图的基础操作(五)

    1.为什么使用视图:      为了提高复杂SQL语句的复用性和表操作的安全性(例如:工资字段不想展示给所有能查看该查询结果的人),MySQL提供了视图特性.所谓视图,本质上是一种虚拟表,其内容与真实的表相似,包含一系列带有名称的列和行数据.但是,视图并不在数据库中以存储数据值的形式存在.行和列的数据来自定义视图的查询所引用基本表,并且在具体使用视图时动态生成.  视图有如下特点;       1. 视图的列可以来自不同的表,是表的抽象和逻辑意义上建立的新关系.       2. 视图是由基本表

  • MySQL中数据视图操作详解

    目录 1.视图概述 1.1创建视图 1.2视图的查询 2.操作视图 2.1通过视图操作数据 2.2修改视图定义 2.3删除视图 1.视图概述 视图是从一个或多个表(或视图)导出的表.视图与表(有时为与视图区别,也称表为基本表)不同,视图是一个虚表,即视图所对应的数据不进行实际存储,数据库中只存储视图的定义,对视图的数据进行操作时,系统根据视图的定义去操作与视图相关联的基本表. 视图一经定义,就可以像表一样被查询.修改.删除和更新.使用视图有下列优点: 1.为用户集中数据,简化用户的数据查询和处理

  • MYSQL中Truncate的用法详解

    本文导读:删除表中的数据的方法有delete,truncate, 其中TRUNCATE TABLE用于删除表中的所有行,而不记录单个行删除操作.TRUNCATE TABLE 与没有 WHERE 子句的 DELETE 语句类似:但是,TRUNCATE TABLE 速度更快,使用的系统资源和事务日志资源更少.下面介绍SQL中Truncate的用法 当你不再需要该表时, 用 drop:当你仍要保留该表,但要删除所有记录时, 用 truncate:当你要删除部分记录时(always with a WHE

  • mysql语法之DQL操作详解

    目录 简单查询 运算符查询 排序查询 聚合查询 分组查询 分页查询 一张表查询结果插入到另一张表 SQL语句分析 DQL小练习1 DQL小练习2 正则表达式 总结 DQL(Data Query Language),数据查询语言,主要是用来查询数据的,这也是SQL中最重要的部分! 简单查询 #DQL操作之基本查询 #创建数据库 CREATE DATABASE IF NOT EXISTS mydb2; #使用数据库 USE mydb2; #创建表 CREATE TABLE IF NOT EXISTS

  • MySql常用数据类型与操作详解

    目录 常用数据类型 数据库基本操作 约束类型 常用数据类型 1.int:整形 2.double(m,d) decimal(m,d):浮点数类型 (m指定长度,d表示小数点位数) 3.varchar(size):字符串类型 4.timestamp:日期类型 数据库基本操作 不管执行什么语句,都要在语句的最后加上:(分号). 1.创建数据库 create database 数据库名: 2.显示当前数据库 show databases; 3.删除数据库 drop database 数据库名; 4.使用

  • SpringBoot yaml语法与数据读取操作详解

    目录 yaml yaml语法规则 字面值表示方式: 数组表示方式: 对象数组格式: 对象数组缩略格式: 读取yaml数据 编写yaml文件 读取单一数据 读取二级数据 读取数组数据 读取服务器端口号 读取对象属性 封装全部数据到Environment对象 读取yaml引用类型属性数据 application.yml MyDataSource 读取数据 变量的引用 application.yml 读取数据 context-path @Autowired报错解决方案 yaml YAML是一种数据序列

  • MySQL数据库中表的操作详解

    目录 1.Mysql中的数据类型 2.创建数据表 3.删除表 4.插入数据 5.更新数据 6.删除数据 7.快速复制表 8.快速删除表数据 1.Mysql中的数据类型 varchar 动态字符串类型(最长255位),可以根据实际长度来动态分配空间,例如:varchar(100) char 定长字符串(最长255位),存储空间是固定的,例如:char(10) int 整数型(最长11位) long 长整型 float 单精度 double 双精度 date 短日期,只包括年月日 datetime

  • 在Tensorflow中实现leakyRelu操作详解(高效)

    从github上转来,实在是厉害的想法,什么时候自己也能写出这种精妙的代码就好了 原地址:简易高效的LeakyReLu实现 代码如下: 我做了些改进,因为实在tensorflow中使用,就将原来的abs()函数替换成了tf.abs() import tensorflow as tf def LeakyRelu(x, leak=0.2, name="LeakyRelu"): with tf.variable_scope(name): f1 = 0.5 * (1 + leak) f2 =

  • mysql中整数数据类型tinyint详解

    目录 1.1 tinyint类型说明 1.2 实践环境说明 1.3 加unsigned属性 1.3.1 SQL模式开启严格模式 1.3.2 SQL模式未开启严格模式 1.4 加zerofill属性 1.4.1 SQL模式开启严格模式 1.4.2 SQL模式未开启严格模式 1.5 不加unsigned和zerofill属性 1.5.1 SQL模式开启严格模式 1.5.2 SQL模式未开启严格模式 1.1 tinyint类型说明 数据类型 显示长度 占用字节 有符号 无符号 tinyint 加上un

  • C语言中的文件操作详解

    目录 1.为什么使用文件 2.什么是文件 2.1程序文件 2.2数据文件 2.3文件名 3.文件的打开和关闭 3.1文件指针 3.2文件的打开和关闭 4.文件的顺序读写 5.文件的随机读写 5.1fseek 5.2ftell 5.3rewind 6.文本文件和二进制文件 7.文件读取结束的判定 7.1被错误使用的feof 8.文件缓冲区 结论 1.为什么使用文件 在学习结构体时,写了一个简易的通讯录的程序,当程序运行起来的时候,可以在通讯录中增加和删除数据,此时数据是存放在内存当中的,当程序退出

  • MySQL学习之数据更新操作详解

    目录 UPDATE 语句 UPDATE 语句练习① UPDATE 语句练习② UPDATE 语句练习③ UPDATE 语句的表连接 UPDATE 语句练习④ UPDATE 语句 UPDATE 语句用于修改表的记录,语法如下 UPDATE IGNORE 表名 SET 字段1=值1, 字段2=值2, 字段3=值3, ...... WHERE 条件1 ...... ORDER BY ...... LIMIT ......; -- 注意:IGNORE - 是可选条件,使用后,会针对有冲突的修改记录忽略

随机推荐