对于mysql数据库视图心得_我的MYSQL学习心得(十一) 视图

本文介绍了MySQL中视图的概念及其作用,如提高安全性、简化复杂查询等。详细阐述了创建视图的语法,包括CREATE VIEW和ALTER VIEW,并通过示例展示了如何创建、修改和删除视图。此外,还讨论了通过视图进行数据更新的条件及限制。
摘要由CSDN通过智能技术生成

这一篇《我的MYSQL学习心得(十一)》将会讲解MYSQL的视图

使用视图的理由是什么?

1、安全性:一般是这样做的:创建一个视图,定义好该视图所操作的数据。

之后将用户权限与视图绑定,这样的方式是使用到了一个特性:grant语句可以针对视图进行授予权限。

2、查询性能提高

3、有灵活性的功能需求后,需要改动表的结构而导致工作量比较大,那么可以使用虚拟表的形式达到少修改的效果。

这是在实际开发中比较有用的

4、复杂的查询需求,可以进行问题分解,然后将创建多个视图获取数据。将视图联合起来就能得到需要的结果了。

创建视图

创建视图的语法

CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]

VIEW view_name [(column_list)]

AS select_statement

[WITH [CASCADED | LOCAL] CHECK OPTION]

其中,CREATE:表示新建视图;

REPLACE:表示替换已有视图

ALGORITHM :表示视图选择算法

view_name :视图名

column_list:属性列

select_statement:表示select语句

[WITH [CASCADED | LOCAL] CHECK OPTION]参数表示视图在更新时保证在视图的权限范围之内

可选的ALGORITHM子句是对标准SQL的MySQL扩展。

ALGORITHM可取三个值:MERGE、TEMPTABLE或UNDEFINED。

如果没有ALGORITHM子句,默认算法是UNDEFINED(未定义的)。算法会影响MySQL处理视图的方式。

对于MERGE,会将引用视图的语句的文本与视图定义合并起来,使得视图定义的某一部分取代语句的对应部分。

对于TEMPTABLE,视图的结果将被置于临时表中,然后使用它执行语句。

对于UNDEFINED,MySQL自己选择所要使用的算法。如果可能,它倾向于MERGE而不是TEMPTABLE,

这是因为MERGE通常更有效,而且如果使用了临时表,视图是不可更新的。

LOCAL和CASCADED为可选参数,决定了检查测试的范围,默认值为CASCADED。

脚本 视图的数据来自于两个表

48304ba5e6f9fe08f3fa1abda7d326ab.png

CREATE TABLE student (stuno INT ,stuname NVARCHAR(60))

CREATE TABLE stuinfo (stuno INT ,class NVARCHAR(60),city NVARCHAR(60))

INSERT INTO student VALUES(1,'wanglin'),(2,'gaoli'),(3,'zhanghai')

INSERT INTO stuinfo VALUES(1,'wuban','henan'),(2,'liuban','hebei'),(3,'qiban','shandong')

-- 创建视图

CREATE VIEW stu_class(id,NAME,glass) AS SELECT student.`stuno`,student.`stuname`,stuinfo.`class`

FROM student ,stuinfo WHERE student.`stuno`=stuinfo.`stuno`

SELECT * FROM stu_class

48304ba5e6f9fe08f3fa1abda7d326ab.png

c4bb3490407bf40c4f6e93c9d0774e5a.png

查看视图

查看视图必须要有SHOW VIEW权限

查看视图的方法包括:DESCRIBE、SHOW TABLE STATUS、SHOW CREATE VIEW

DESCRIBE查看视图基本信息

DESCRIBE 视图名

DESCRIBE stu_class

0274139c5ce10c9356e484b0c42bdf20.png

结果显示了视图的字段定义、字段的数据类型、是否为空、是否为主/外键、默认值和额外信息

DESCRIBE一般都简写成DESC

SHOW TABLE STATUS语句查看查看视图基本信息

查看视图的信息可以通过SHOW TABLE STATUS的方法

SHOW TABLE STATUS LIKE 'stu_class'

Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time Collation Checksum Create_options Comment

--------- ------ ------- ---------- ------ -------------- ----------- --------------- ------------ --------- -------------- ----------- ----------- ---------- --------- -------- -------------- -------

stu_class (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) (NULL) VIEW

COMMENT的值为VIEW说明该表为视图,其他的信息为NULL说明这是一个虚表,如果是基表那么会基表的信息,这是基表和视图的区别

SHOW CREATE VIEW语句查看视图详细信息

SHOW CREATE VIEW stu_class

48304ba5e6f9fe08f3fa1abda7d326ab.png

View Create View character_set_client collation_connection

--------- ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ -------------------- --------------------

stu_class CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `stu_class` AS select `student`.`stuno` AS `id`,`student`.`stuname` AS `name`,`stuinfo`.`class` AS `class` from (`student` join `stuinfo`) where (`student`.`stuno` = `stuinfo`.`stuno`) utf8 utf8_general_ci

48304ba5e6f9fe08f3fa1abda7d326ab.png

执行结果显示视图的名称、创建视图的语句等信息

在VIEWS表中查看视图的详细信息

在MYSQL中,INFORMATION_SCHEMA VIEWS表存储了关于数据库中的视图的信息

通过对VIEWS表的查询可以查看数据库中所有视图的详细信息

SELECT * FROM `information_schema`.`VIEWS`

48304ba5e6f9fe08f3fa1abda7d326ab.png

TABLE_CATALOG TABLE_SCHEMA TABLE_NAME VIEW_DEFINITION CHECK_OPTION IS_UPDATABLE DEFINER SECURITY_TYPE CHARACTER_SET_CLIENT COLLATION_CONNECTION

------------- ------------ ---------- -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- ------------ ------------ -------------- ------------- -------------------- --------------------

def school stu_class select `school`.`student`.`stuno` AS `id`,`school`.`student`.`stuname` AS `name`,`school`.`stuinfo`.`class` AS `class` from `school`.`student` join `school`.`stuinfo` where (`school`.`student`.`stuno` = `school`.`stuinfo`.`stuno`) NONE YES root@localhost DEFINER utf8 utf8_general_ci

48304ba5e6f9fe08f3fa1abda7d326ab.png

当前实例下只有一个视图stu_class

20f176f75fc805a53821c1b2731d352d.png

修改视图

修改视图是指修改数据库中存在的视图,当基本表的某些字段发生变化时,可以通过修改视图来保持与基本表的一致性。

MYSQL中通过CREATE OR REPLACE VIEW 语句和ALTER语句来修改视图

语法如下:

ALTER OR REPLACE [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]

VIEW view_name [(column_list)]

AS select_statement

[WITH [CASCADED | LOCAL] CHECK OPTION]

该语句用于更改已有视图的定义。其语法与CREATE VIEW类似。当视图不存在时创建,存在时进行修改

修改视图

48304ba5e6f9fe08f3fa1abda7d326ab.png

DELIMITER $$

CREATE OR REPLACE VIEW `stu_class` AS

SELECT

`student`.`stuno` AS `id`

FROM (`student` JOIN `stuinfo`)

WHERE (`student`.`stuno` = `stuinfo`.`stuno`)$$

DELIMITER ;

48304ba5e6f9fe08f3fa1abda7d326ab.png

通过DESC来查看更改之后的视图定义

DESC stu_class

529593bb5ba30b9c1bdd6a83ef873e43.png

可以看到只查询一个字段

ALTER语句修改视图

ALTER [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]

VIEW view_name [(column_list)]

AS select_statement

[WITH [CASCADED | LOCAL] CHECK OPTION]

这里关键字跟前面的一样,这里不做介绍

使用ALTER语句修改视图 stu_class

ALTER VIEW stu_class AS SELECT stuno FROM student;

使用DESC查看

DESC stu_class

2c20cf99625229c5febbe5aa54c5fd63.png

69c6a690726931364864649f16dd3ac9.png

更新视图

更新视图是指通过视图来插入、更新、删除表数据,因为视图是虚表,其中没有数据。

通过视图更新的时候都是转到基表进行更新,如果对视图增加或者删除记录,实际上是对基表增加或删除记录

我们先修改一下视图定义

ALTER VIEW stu_class AS SELECT stuno,stuname FROM student;

查询视图数据

e84904dada2f856e5dcd8bfcbf68e7f6.png

UPDATE

UPDATE stu_class SET stuname='xiaofang' WHERE stuno=2

查询视图数据

296d8c1a96c4a0630b3eba48189d31d3.png

更新成功

INSERT

INSERT INTO stu_class VALUES(6,'haojie')

3e921934d5584d14e80dc2fbc2e1b2e8.png

插入成功

DELETE

DELETE FROM stu_class WHERE stuno=1

6bd884947c425c28f10486027fabfa3e.png

删除成功

当视图中包含如下内容的时候,视图的更新操作将不能被执行

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

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

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

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

删除视图

删除视图使用DROP VIEW语法

DROP VIEW [IF EXISTS]

view_name [, view_name] ...

[RESTRICT | CASCADE]

DROP VIEW能够删除1个或多个视图。必须在每个视图上拥有DROP权限

可以使用关键字IF EXISTS来防止因不存在的视图而出错

删除stu_class视图

DROP VIEW IF EXISTS stu_class

如果名称为 stu_class 的视图存在则删除

使用SHOW CREATE VIEW语句查看结果

SHOW CREATE VIEW stu_class

48304ba5e6f9fe08f3fa1abda7d326ab.png

Query: -- update stu_class set stuname='xiaofang' where stuno=2; -- delete from stu_class where stuno=1 -- select * from stu_class; -- ...

Error Code: 1146

Table 'school.stu_class' doesn't exist

Execution Time : 0 sec

Transfer Time : 0 sec

Total Time : 0.004 sec

---------------------------------------------------

48304ba5e6f9fe08f3fa1abda7d326ab.png

该视图不存在,删除成功

总结

SQLSERVER里实际上跟MYSQL一样,也是有信息架构视图的

信息架构视图是 SQL Server 提供的几种获取元数据的方法之一。

信息架构视图提供独立于系统表的内部 SQL Server 元数据视图。

尽管已经对基础系统表进行了重要的修改,信息架构视图仍然可使应用程序正常工作。

SQL Server 中包含的信息架构视图符合 ISO 标准中的信息架构定义。

信息架构视图的数据是存放在系统数据库Resource 数据库里面

mssqlsystemresource.mdf

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值