mysql中sql的生命周期是什么

发布时间:2020-11-16 10:00:41 作者:小新
来源:亿速云 阅读:963

这篇文章主要介绍mysql中sql的生命周期是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

MYSQL Query Processing

sql的执行过程和mysql体系架构基本一致

执行过程:

mysql中sql的生命周期是什么

连接器:

建立与 MySQL 的连接,用于查询SQL语句,判断权限 。

查询缓存:

分析器:

对 SQL 语句进行硬解析,分析器先会做词法分析。分析SQL 语句的组成成分。判断输入的 SQL 语句是否满足语法规则。

优化器:

优化器是在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多表关联(join)的时候,决定各个表的连接顺序。 不同的执行方法的逻辑结果是一样的,但是执行的效率会有不同,而优化器的作用就是决定选择使用哪一个方案。

执行器:

理解执行计划

EXPLAIN命令输出MySQL将如何执行你的SQL语句,但不会返回数据

如何使用

[root@localhost][(none)]> explain select * from 表名 where project_id = 36;
+----+-------------+--------------------------+------------+------+---------------+------------+---------+-------+--------+----------+-------+
| id | select_type | table                    | partitions | type | possible_keys | key        | key_len | ref   | rows   | filtered | Extra |
+----+-------------+--------------------------+------------+------+---------------+------------+---------+-------+--------+----------+-------+
|  1 | SIMPLE      | 表名                     | NULL       | ref  | project_id    | project_id | 4       | const | 797964 |   100.00 | NULL  |
+----+-------------+--------------------------+------------+------+---------------+------------+---------+-------+--------+----------+-------+复制代码

id

select_type

table

type

system > const > eq_ref > ref > range > index > ALL(查询效率)

possible_keys

key

key_length

ref

rows

filtered

extra

光看 filesort 字面意思,可能以为是要利用磁盘文件进行排序,实则不全然。 当MySQL不能使用索引进行排序时,就会利用自己的排序算法(快速排序算法)在内存(sort buffer)中对数据进行排序,如果内存装载不下,它会将磁盘上的数据进行分块,再对各个 数据块进行排序,然后将各个块合并成有序的结果集(实际上就是外排序)。

当对连接操作进行排序时,如果ORDER BY仅仅引用第一个表的列,MySQL对该表进行filesort操作,然后进行连接处理,此时,EXPLAIN输出“Using filesort”;否则,MySQL必 须将查询的结果集生成一个临时表,在连接完成之后行行filesort操作,此时,EXPLAIN输出“Using temporary;Using filesort”。

提高查询效率

正确使用索引

为解释方便,来一个demo:

DROP TABLE IF EXISTS user; 
CREATE TABLE user( 
id int AUTO_INCREMENT PRIMARY KEY, 
user_name varchar(30) NOT NULL, 
gender bit(1) NOT NULL DEFAULT b’1’, 
city varchar(50) NOT NULL, 
age int NOT NULL 
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
ALTER TABLE user ADD INDEX idx_user(user_name , city , age); 
复制代码

什么样的索引可以被使用?

什么样的索引无法被使用?

SELECT * FROM user WHERE city='上海';

SELECT * FROM user WHERE age='26';

SELECT * FROM user WHERE age='26' AND city=‘上海';

SELECT * FROM user WHERE user_name LIKE '%N';

SELECT * FROM user WHERE user_name='JueJin' AND city LIKE '上%' AND age=31;

SELECT * FROM user WHERE user_name=concat(user_name,'PLUS');

选择合适的索引列顺序

覆盖索引条件

SELECT user_name, city, age FROM user WHERE user_name='Tony' AND age='28' AND city='上海';

因为要查询的字段(user_name, city, age)都包含在组合索引的索引列中,所以就使用了覆盖索引查询,查看是否使用了覆盖索引可以通过执行计划中的Extra中的值为Using index则证明使用了覆盖索引,覆盖索引可以极大的提高访问性能。

使用索引进行排序

在排序操作中如果能使用到索引来排序,那么可以极大地提高排序的速度,要使用索引来排序需要满足以下两点即可:

排序可用demo:

排序不可用demo:

数据获取建议

不要返回应用户程序所不需要的数据限制返回数

LIMIT:MySQL并不能按照需求返回数据量,也就是MySQL总是会查询出全部数据,使用LIMIT子句其实是为了减小网络数据传输的压力,并不会减小数据的读取行数。

去掉不需要的列

正确使用索引的优点

  1. 单表查询时,全表扫描需要查询每一行
  2. 多表查询时,全表扫描至少需要检索所有表中每一行
  1. 可以迅速定位结果集的第一行
  2. 排除不相关的结果
  3. 对于MIN()或者MAX()值不必检查每一行

索引的代价

  1. 受影响的索引需要被更新
  2. 对于写密集型环境压力很大
  1. InnoDB存储引擎将索引和数据存储在一起
  2. 需要监控磁盘空间

索引最佳实践

对于如下列考虑使用索引

考虑针对字符串型列使用前缀索引

SELECT语句效率低下时考虑

  1. WHERE语句
  2. 表连接条件

调优表连接方法

以上是mysql中sql的生命周期是什么的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

推荐阅读:
  1. MySQL中SQL模式的特点是什么
  2. sql与mysql的区别是什么

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sql生命周期 mysql

上一篇:jquery属性过滤选择器有哪些

下一篇:react中dva的作用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》