我的MYSQL学习心得.docx

上传人:b****6 文档编号:4825969 上传时间:2022-12-09 格式:DOCX 页数:9 大小:18.57KB
下载 相关 举报
我的MYSQL学习心得.docx_第1页
第1页 / 共9页
我的MYSQL学习心得.docx_第2页
第2页 / 共9页
我的MYSQL学习心得.docx_第3页
第3页 / 共9页
我的MYSQL学习心得.docx_第4页
第4页 / 共9页
我的MYSQL学习心得.docx_第5页
第5页 / 共9页
点击查看更多>>
下载资源
资源描述

我的MYSQL学习心得.docx

《我的MYSQL学习心得.docx》由会员分享,可在线阅读,更多相关《我的MYSQL学习心得.docx(9页珍藏版)》请在冰豆网上搜索。

我的MYSQL学习心得.docx

我的MYSQL学习心得

我的MYSQL学习心得(十一) 视图

我的MYSQL学习心得

(一)简单语法

我的MYSQL学习心得

(二)数据类型宽度

我的MYSQL学习心得(三)查看字段长度

我的MYSQL学习心得(四)数据类型

我的MYSQL学习心得(五)运算符

我的MYSQL学习心得(六)函数

我的MYSQL学习心得(七)查询

我的MYSQL学习心得(八)插入更新删除

我的MYSQL学习心得(九)索引

我的MYSQL学习心得(十)自定义存储过程和函数

我的MYSQL学习心得(十二)触发器

我的MYSQL学习心得(十三)权限管理

我的MYSQL学习心得(十四)备份和恢复

我的MYSQL学习心得(十五)日志

我的MYSQL学习心得(十六)优化

我的MYSQL学习心得(十七)复制

 

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

 

使用视图的理由是什么?

1、安全性:

一般是这样做的:

创建一个视图,定义好该视图所操作的数据。

之后将用户权限与视图绑定,这样的方式是使用到了一个特性:

grant语句可以针对视图进行授予权限。

2、查询性能提高

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

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

4、复杂的查询需求,可以进行问题分解,然后将创建多个视图获取数据。

将视图联合起来就能得到需要的结果了。

创建视图

创建视图的语法

CREATE[ORREPLACE][ALGORITHM={UNDEFINED|MERGE|TEMPTABLE}]

VIEWview_name[(column_list)]

ASselect_statement

[WITH[CASCADED|LOCAL]CHECKOPTION]

其中,CREATE:

表示新建视图;

REPLACE:

表示替换已有视图

ALGORITHM:

表示视图选择算法

view_name:

视图名

column_list:

属性列

select_statement:

表示select语句

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

 

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

ALGORITHM可取三个值:

MERGE、TEMPTABLE或UNDEFINED。

如果没有ALGORITHM子句,默认算法是UNDEFINED(未定义的)。

算法会影响MySQL处理视图的方式。

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

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

对于UNDEFINED,MySQL自己选择所要使用的算法。

如果可能,它倾向于MERGE而不是TEMPTABLE,

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

 

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

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

CREATETABLEstudent(stunoINT,stunameNVARCHAR(60))

CREATETABLEstuinfo(stunoINT,classNVARCHAR(60),cityNVARCHAR(60))

INSERTINTOstudentVALUES(1,'wanglin'),(2,'gaoli'),(3,'zhanghai')

INSERTINTOstuinfoVALUES(1,'wuban','henan'),(2,'liuban','hebei'),(3,'qiban','shandong')

--创建视图

CREATEVIEWstu_class(id,NAME,glass)ASSELECTstudent.`stuno`,student.`stuname`,stuinfo.`class`

FROMstudent,stuinfoWHEREstudent.`stuno`=stuinfo.`stuno`

SELECT*FROMstu_class

查看视图

查看视图必须要有SHOWVIEW权限

查看视图的方法包括:

DESCRIBE、SHOWTABLESTATUS、SHOWCREATEVIEW

DESCRIBE查看视图基本信息

DESCRIBE视图名

DESCRIBEstu_class

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

DESCRIBE一般都简写成DESC

 

SHOWTABLESTATUS语句查看查看视图基本信息

查看视图的信息可以通过SHOWTABLESTATUS的方法

SHOWTABLESTATUSLIKE'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说明这是一个虚表,如果是基表那么会基表的信息,这是基表和视图的区别

 

SHOWCREATEVIEW语句查看视图详细信息

SHOWCREATEVIEWstu_class

View   CreateView                                                                                                                               character_set_client collation_connection

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

stu_class CREATEALGORITHM=UNDEFINEDDEFINER=`root`@`localhost`SQLSECURITYDEFINERVIEW`stu_class`ASselect`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  

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

 

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

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

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

SELECT*FROM`information_schema`.`VIEWS`

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  

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

修改视图

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

MYSQL中通过CREATEORREPLACEVIEW语句和ALTER语句来修改视图

语法如下:

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

VIEWview_name[(column_list)]

ASselect_statement

[WITH[CASCADED|LOCAL]CHECKOPTION]

该语句用于更改已有视图的定义。

其语法与CREATEVIEW类似。

当视图不存在时创建,存在时进行修改

 

修改视图

DELIMITER$$

CREATEORREPLACEVIEW`stu_class`AS

SELECT

`student`.`stuno` AS`id`

FROM(`student`JOIN`stuinfo`)

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

DELIMITER;

 

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

DESCstu_class

可以看到只查询一个字段

 

ALTER语句修改视图

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

VIEWview_name[(column_list)]

ASselect_statement

[WITH[CASCADED|LOCAL]CHECKOPTION]

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

 

使用ALTER语句修改视图 stu_class

ALTERVIEW stu_classASSELECTstunoFROMstudent;

使用DESC查看

DESCstu_class

更新视图

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

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

 

我们先修改一下视图定义

ALTERVIEW stu_classASSELECTstuno,stunameFROMstudent;

查询视图数据

 

UPDATE

UPDATEstu_classSETstuname='xiaofang'WHEREstuno=2

查询视图数据

更新成功

 

INSERT

INSERTINTOstu_classVALUES(6,'haojie')

插入成功

 

DELETE

DELETEFROMstu_classWHEREstuno=1

删除成功

 

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

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

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

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

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

 

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育 > 学科竞赛

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1