我的MYSQL学习心得(十一)
我的MYSQL学习心得(一)
我的MYSQL学习心得(二)
我的MYSQL学习心得(三)
我的MYSQL学习心得(四)
我的MYSQL学习心得(五)
我的MYSQL学习心得(六)
我的MYSQL学习心得(七)
我的MYSQL学习心得(八)
我的MYSQL学习心得(九)
我的MYSQL学习心得(十)
这一篇《我的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。
脚本 视图的数据来自于两个表
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
查看视图
查看视图必须要有SHOW VIEW权限
查看视图的方法包括:DESCRIBE、SHOW TABLE STATUS、SHOW CREATE VIEW
DESCRIBE查看视图基本信息
DESCRIBE 视图名
DESCRIBE stu_class
结果显示了视图的字段定义、字段的数据类型、是否为空、是否为主/外键、默认值和额外信息
DESCRIBE一般都简写成DESC
SHOW TABLE STATUS语句查看查看视图基本信息
查看视图的信息可以通过SHOW TABLE STATUS的方法
SHOW TABLE STATUS LIKE 'stu_class'
Name EngineVersionRow_formatRowsAvg_row_lengthData_lengthMax_data_lengthIndex_lengthData_freeAuto_incrementCreate_timeUpdate_timeCheck_timeCollationChecksumCreate_optionsComment---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------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
View Create View character_set_clientcollation_connection-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------stu_classCREATE 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`)utf8utf8_general_ci
执行结果显示视图的名称、创建视图的语句等信息
在VIEWS表中查看视图的详细信息
在MYSQL中,INFORMATION_SCHEMA VIEWS表存储了关于数据库中的视图的信息
通过对VIEWS表的查询可以查看数据库中所有视图的详细信息
SELECT * FROM `information_schema`.`VIEWS`
TABLE_CATALOGTABLE_SCHEMATABLE_NAMEVIEW_DEFINITION CHECK_OPTIONIS_UPDATABLEDEFINER SECURITY_TYPECHARACTER_SET_CLIENTCOLLATION_CONNECTION--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------defschoolstu_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`)NONEYES root@localhostDEFINERutf8utf8_general_ci
当前实例下只有一个视图stu_class
修改视图
修改视图是指修改数据库中存在的视图,当基本表的某些字段发生变化时,可以通过修改视图来保持与基本表的一致性。
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类似。当视图不存在时创建,存在时进行修改
修改视图
DELIMITER $$CREATE OR REPLACE VIEW `stu_class` AS SELECT`student`.`stuno` AS `id`FROM (`student` JOIN `stuinfo`)WHERE (`student`.`stuno` = `stuinfo`.`stuno`)$$DELIMITER ;
通过DESC来查看更改之后的视图定义
DESC stu_class
可以看到只查询一个字段
ALTER语句修改视图
ALTER [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]VIEW view_name [(column_list)]AS select_statement[WITH [CASCADED | LOCAL] CHECK OPTION]
这里关键字跟前面的一样,这里不做介绍
使用ALTER语句修改视图 stu_class
ALTER VIEWstu_class AS SELECT stuno FROM student;
使用DESC查看
DESC stu_class
更新视图
更新视图是指通过视图来插入、更新、删除表数据,因为视图是虚表,其中没有数据。
通过视图更新的时候都是转到基表进行更新,如果对视图增加或者删除记录,实际上是对基表增加或删除记录
我们先修改一下视图定义
ALTER VIEWstu_class AS SELECT stuno,stuname FROM student;
查询视图数据
UPDATE
UPDATE stu_class SET stuname='xiaofang' WHERE stuno=2
查询视图数据
更新成功
INSERT
INSERT INTO stu_class VALUES(6,'haojie')
插入成功
DELETE
DELETE FROM stu_class WHERE stuno=1
删除成功
当视图中包含如下内容的时候,视图的更新操作将不能被执行
(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
Query: -- update stu_class set stuname='xiaofang' where stuno=2; -- delete from stu_class where stuno=1 -- select * from stu_class; -- ...Error Code: 1146Table 'school.stu_class' doesn't existExecution Time : 0 secTransfer Time: 0 secTotal Time : 0.004 sec---------------------------------------------------
该视图不存在,删除成功
总结
SQLSERVER 里实际上跟 MYSQL 一样,也是有信息架构视图的
信息架构视图 (Transact-SQL)
信息架构视图是 SQL Server 提供的几种获取元数据的方法之一。
信息架构视图提供独立于系统表的内部 SQL Server 元数据视图。
尽管已经对基础系统表进行了重要的修改,信息架构视图仍然可使应用程序正常工作。
SQL Server 中包含的信息架构视图符合 ISO 标准中的信息架构定义。
信息架构视图的数据是存放在系统数据库 Resource 数据库 里面
mssqlsystemresource.mdf
利用INFORMATION_SCHEMA视图来拼接 SQL 语句
如有不对的地方,欢迎大家拍砖o(∩_∩)o

在数据库优化中,应根据查询需求选择索引策略:1.当查询涉及多个列且条件顺序固定时,使用复合索引;2.当查询涉及多个列但条件顺序不固定时,使用多个单列索引。复合索引适用于优化多列查询,单列索引则适合单列查询。

要优化MySQL慢查询,需使用slowquerylog和performance_schema:1.启用slowquerylog并设置阈值,记录慢查询;2.利用performance_schema分析查询执行细节,找出性能瓶颈并优化。

MySQL和SQL是开发者必备技能。1.MySQL是开源的关系型数据库管理系统,SQL是用于管理和操作数据库的标准语言。2.MySQL通过高效的数据存储和检索功能支持多种存储引擎,SQL通过简单语句完成复杂数据操作。3.使用示例包括基本查询和高级查询,如按条件过滤和排序。4.常见错误包括语法错误和性能问题,可通过检查SQL语句和使用EXPLAIN命令优化。5.性能优化技巧包括使用索引、避免全表扫描、优化JOIN操作和提升代码可读性。

MySQL异步主从复制通过binlog实现数据同步,提升读性能和高可用性。1)主服务器记录变更到binlog;2)从服务器通过I/O线程读取binlog;3)从服务器的SQL线程应用binlog同步数据。

MySQL是一个开源的关系型数据库管理系统。1)创建数据库和表:使用CREATEDATABASE和CREATETABLE命令。2)基本操作:INSERT、UPDATE、DELETE和SELECT。3)高级操作:JOIN、子查询和事务处理。4)调试技巧:检查语法、数据类型和权限。5)优化建议:使用索引、避免SELECT*和使用事务。

MySQL的安装和基本操作包括:1.下载并安装MySQL,设置根用户密码;2.使用SQL命令创建数据库和表,如CREATEDATABASE和CREATETABLE;3.执行CRUD操作,使用INSERT,SELECT,UPDATE,DELETE命令;4.创建索引和存储过程以优化性能和实现复杂逻辑。通过这些步骤,你可以从零开始构建和管理MySQL数据库。

InnoDBBufferPool通过将数据和索引页加载到内存中来提升MySQL数据库的性能。1)数据页加载到BufferPool中,减少磁盘I/O。2)脏页被标记并定期刷新到磁盘。3)LRU算法管理数据页淘汰。4)预读机制提前加载可能需要的数据页。

MySQL适合初学者使用,因为它安装简单、功能强大且易于管理数据。1.安装和配置简单,适用于多种操作系统。2.支持基本操作如创建数据库和表、插入、查询、更新和删除数据。3.提供高级功能如JOIN操作和子查询。4.可以通过索引、查询优化和分表分区来提升性能。5.支持备份、恢复和安全措施,确保数据的安全和一致性。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

SublimeText3汉化版
中文版,非常好用

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。