【数据库优化专题】MySQL视图优化(一)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

本期数据库优化专题分享,为大家带来的是DBA+社群MySQL领域原创专家——李海翔所著的MySQL视图优化系列文章。以下是第一部分的内容,未完部分敬请关注后续更新。

 

专家简介

  
20151106021005275.png

李海翔

网名:那海蓝蓝

DBA+社群MySQL领域原创专家

 

从事数据库研发、数据库测试与技术管理等工作10余年,对数据库的内核有深入研究,擅长于PostgreSQL和MySQL等开源数据库的内核与架构。现任职于Oracle公司MySQL全球开发团队,从事查询优化技术的研究和MySQL查询优化器的开发工作。著有《数据库查询优化器的艺术》一书。

 

 

 

 

一、什么是视图

 

这个标题似乎有点简单了,一些人会想:作为一名数据库从业者,作为一名经验丰富的DBA,天天与视图打交道, 怎么能不知道什么是视图呢?

 

请在继续阅读之前,微闭双目,休息之余想一想, 什么是视图?思索之后,且与如下标准定义做个比较。

 

SQL标准定义是如下定义视图的:

 

20151106020748905.jpg

 

1、首先,视图本质上,就是一个“查询”,而且是一个“有名字的查询”,名字是谁?——视图的名称。这就引申出另外一些概念,什么是查询?SQL标准做出如下定义:

 

1.1、base table:基表

 

SQL-data consists entirely of table variables,called base tables.

 

SQL-data构成的完整的表变量的组合,称为基表。即SQL-data的集合。

 

思考一个问题,CREATE TABLE+INSERT语句建表并插入一些数据后,其生成物,是否可以称为“base table”?

 

1.2、query,查询

 

An operation that references zero or more base tables and returns a table is called a query.

 

引用零个基表(如SELECT 1;则是引用零个基表)或多个基表(多表连接操作)的操作(查询操作)并且返回一个“table”,这样的操作称为“query”(查询)。可见query是一个“过程”且有结果,而非一个“查询语句”(SELECT statement)。

 

1.3、视图的值,是此有名字的查询操作的执行结果。

 

2、table,表。回答1.1中的问题,base table 和table是有区别的。

 

A table has an ordered collection of one or more columns and an unordered collection of zero or more rows.

 

从上面的定义可以看出,table除了SQL-data外,还有“zero or more rows”,即数据。

 

3、那么,什么是SQL-data?

 

SQL-data is data described by SQL-schemas — data that is under the control of an SQL-implementation in an SQL-environment.

 

SQL-schemas和SQL-implementation以及SQL-environment的定义参见SQL标准(如果展开,越展越多)。我们可以简单认为SQL-data就是描述“字段”的数据。所以SQL-data可以用以表述表的定义,即base table。

 

4、与view相似的一个概念,称为“派生表”,其SQL标准的定义如下:

 

The result of a query is called a derived table.

 

一个查询的结果被称为派生表。即派生表也是一个有结果的查询。而视图是查询的一种,视图的值是查询的结果,那么派生表和视图之间有什么差别呢?从形式上看,二者差别仅在于是否有名字。

 

一个新的问题随之而来:Q1:在MySQL中,视图和派生表有差别吗?他们的处理方式一样吗?

 

未完待续……敬请持续关注~


本文来自云栖社区合作伙伴"DBAplus",原文发布时间:2015-11-06

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7天前
|
SQL 缓存 关系型数据库
下次老板问你MySQL如何优化时,你可以这样说,老板默默给你加工资
【5月更文挑战第20天】下次老板问你MySQL如何优化时,你可以这样说,老板默默给你加工资
28 3
|
2天前
|
SQL 关系型数据库 MySQL
mysql 故障排除与优化
mysql 故障排除与优化
|
2天前
|
存储 SQL 关系型数据库
mysql 高阶语句 与视图
mysql 高阶语句 与视图
|
3天前
|
SQL 关系型数据库 MySQL
MySQL in 太慢的 3 种优化方案
MySQL中的`eq_range_index_dive_limit`参数默认值为200,影响了IN查询的执行方式。当IN列表项少于这个值时,MySQL会使用扫描索引树(精确成本计算),而多于此值则使用索引统计(快速但可能不准)来分析查询成本。大量IN值可能导致性能下降。解决方案包括:1) 分批查询;2) 使用UNION ALL创建内存临时表;3) 创建实体表存储IN值并进行JOIN操作。注意,实体表需及时清理并避免反复插入删除导致性能下降。
|
4天前
|
存储 监控 关系型数据库
关系型数据库数据库设计优化
【5月更文挑战第18天】关系型数据库数据库设计优化
18 1
|
4天前
|
SQL 缓存 监控
关系型数据库优化查询语句
【5月更文挑战第18天】
15 2
|
4天前
|
关系型数据库 MySQL 数据库
关系型数据库索引设计优化
【5月更文挑战第18天】
13 1
|
6天前
|
SQL 关系型数据库 分布式数据库
【PolarDB开源】PolarDB Proxy配置与优化:提升数据库访问效率
【5月更文挑战第27天】PolarDB Proxy是阿里云PolarDB的高性能数据库代理,负责SQL请求转发和负载均衡。其关键配置包括:连接池管理(如最大连接数、空闲超时时间),负载均衡策略(轮询、权重轮询、一致性哈希),以及SQL过滤规则。优化方面,关注监控与调优、缓存策略、网络优化。通过这些措施,可提升数据库访问效率和系统稳定性。
105 1
|
15天前
|
关系型数据库 MySQL API
实时计算 Flink版产品使用合集之可以通过mysql-cdc动态监听MySQL数据库的数据变动吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
124 0
|
10天前
|
存储 SQL 关系型数据库
【MySQL】数据库基础 -- 详解
【MySQL】数据库基础 -- 详解