Mysql 语句优化
- 通过 show status 命令了解各个 sql 语句的执行频率
格式:Mysql> show [session | global] status;
注:session 表示当前连接
global 表示自数据库启动至今
eg:Mysql> show status;
Mysql> show global status;
Mysql> show status like 'Com_%';
Mysql> show global status like 'Com_%';
**** 判断字段是否需要添加索引,并使用 explain、desc 查看它影响的行数多不多
a、查看慢查询日志
b、通过解析 Sql 语句,判断影响行数
c、通过影响的行数,判断是否需要添加索引,以及索引能否使用
参数说明
Com_xxx 表示 xxx 语句执行的次数:
Com_select:执行 select 操作的次数,一次查询叠加一次
Com_update: 执行 update 操作的次数
Com_insert: 执行 insert 操作的次数,对批量插入只算一次
Com_delete: 执行 delete 删除操作的次数
只针对 innodb 存储引擎
Innodb_rows_read: 执行 select 操作行的次数
Innodb_rows_updated: 执行 update 操作行的次数
Innodb_rows_inserted: 执行 insert 操作行的次数
Innodb_rows_deleted: 执行 delete 操作行的次数
Others:
connections: 连接 Mysql 的次数 (成功、失败都记录)
Uptime 服务器已经工作的秒数
Slow_queries: 慢查询的次数 - 定位执行效率较低的 SQL 语句 (显示详细的执行效率)
a、explain select * from table where id = 1000;
b、desc select * from table where id = 1000;
参数解释:
select_type: 表示 select 的类型。
SIMPLE 表示不使用表连接或子查询
PRIMARY 表示主查询,即外层查询
UNION 表示多个查询合并
SUBQUERY 表示子查询的第一个 select
table: stu 表示结果集的表
type: range 表示表的连接类型,性能不一。
system 表示表仅有一行
const 表示只一行匹配
eq_ref 表示对于前面使用的每一行使用主键和唯一
ref 表示没有使用主键或唯一
ref_or_null 表示没有使用主键和唯一同时对 Null 查询
index_merge 表示索引合并优化
unique_subquery 表示 in 的后面是一个查询主键字段的子查询
index_subsquery 表示非主键子查询
range 表示区间查询
ndex 表示都通过查询索引得到数据
all 表示扫描全表得到的数据(尽量避免)
possible_keys: 表查询是可能使用到的索引
key: 实际使用到的索引
key_len: 索引字段的长度
rows: 扫描行的数量
Extra: Using where、Using index 执行情况说明
其他查询语句:
Mysql> show variables like "%log%";
Mysql> show variables like "%long%" // 慢查询设置的时间
set global slow_query_log='ON'; 启用慢查询;
set global long_query_time=4;
Mysql 语句优化的更多相关文章
- php代码优化,mysql语句优化,面试需要用到的
首先说个问题,就是这些所谓的优化其实代码标准化的建议,其实真算不上什么正真意义上的优化,还有一点需要指出的为了一丁点的性能优化,甚至在代码上的在一次请求上性能提升万分之一的所谓就去大面积改变代码习惯, ...
- MySql基础笔记(二)Mysql语句优化---索引
Mysql语句优化--索引 一.开始优化前的准备 一)explain语句 当MySql要执行一个查询语句的时候,它首先会对语句进行语法检查,然后生成一个QEP(Query Execution Plan ...
- Mysql语句优化
总结总结自己犯过的错,网上说的与自己的Mysql语句优化的想法. 1.查询数据库的语句的字段,尽量做到用多少写多少. 2.建索引,确保查询速度. 3.orm框架自带的方法会损耗一部分性能,这个性能应该 ...
- mysql语句优化原则
有时候发现数据量大的时候查询起来效率就比较慢了,学习一下mysql语句优化的原则,自己在正常写sql的时候还没注意到这些,先记录下来,慢慢一点一点的学,加油! 这几篇博客写的都可以: https:// ...
- mysql语句优化总结(一)
Sql语句优化和索引 1.Innerjoin和左连接,右连接,子查询 A. inner join内连接也叫等值连接是,left/rightjoin是外连接. SELECT A.id,A.nam ...
- Mysql 语句优化技巧
前言 有人反馈之前几篇文章过于理论缺少实际操作细节,这篇文章就多一些可操作性的内容吧. 注:这篇文章是以 MySQL 为背景,很多内容同时适用于其他关系型数据库,需要有一些索引知识为基础. 优化目标 ...
- mysql语句优化方案(网上流传)
关于mysql处理百万级以上的数据时如何提高其查询速度的方法 最近一段时间由于工作需要,开始关注针对Mysql数据库的select查询语句的相关优化方法. 由于在参与的实际项目中发现当mysql表的数 ...
- Mysql语句优化建议
一.建立索引 1)考虑在 where 及 order by 涉及的列上建立索引 2)对于模糊查询, 建立全文索引 3)对于多主键查询,建立组合索引 二.避免陷阱 然而,一些情况下可能使索引无效: 1) ...
- MySQL语句优化方法(简单版)
基础回顾: sql语句是怎么样运行的? 一般来说,客户端发送sql语句到数据库服务器——数据库服务器进行运算并返回结果——客户端显示sql语句运行结果. 在本地运行时以workbench为例,客户端为 ...
随机推荐
- 百度地图开发者API学习笔记一(转载)
一,实现功能: 在地图上标记点,划线等操作.如下图. 2.代码: <!DOCTYPE html> <html> <head> <meta http-equiv ...
- 11-vue的使用
一.安装 对于新手来说,强烈建议大家使用<script>引入 二. 引入vue.js文件 我们能发现,引入vue.js文件之后,Vue被注册为一个全局的变量,它是一个构造函数. 三.使用V ...
- 一、npm基础
一.什么是npm? npm 是模块管理工具,可以下载.更新第三方模块,也可以发布自己的模块共替他人使用,主要目的在于分享和重用代码: 二.下载安装node,更新npm node 下载网址 https ...
- API知识点总结
一.开发api接口开放给其他人调用的api接口(短信接口,支付宝api) 二.api安全弱点数据窃取(解决加密),数据篡改(解决MD5),数据泄露(爬虫技术)(解决令牌)1.加密(HTTPS传输-收费 ...
- Flutter的scope_model使用mixin语法报错
在pubspec.yaml同级目录下创建analysis_options.yaml文件,内容: # https://www.dartlang.org/guides/language/analysis- ...
- 安装 Tesserocr (填坑)
参考: https://www.imooc.com/article/45278?block_id=tuijian_wz
- mysql参数优化记录
服务器参数16G内存,4核CPUvim /etc/my.cnf 原: back_log=170 max_connections=600 max_user_connections=0 thread_co ...
- python数据结构与算法第十天【插入排序】
1.插入排序的原理 2.代码实现 def insert_sort(alist): # 从第二个位置,即下标为1的元素开始向前插入 for i in range(1, len(alist)): # 从第 ...
- Vue簡介
vue使用由下向上的增量開發模型: vue是javascript的漸進框架: vue的目標是盡量使用簡單的API實現響應的數據綁定和組合的視圖組件.
- 各个版本spring的jar包以及源码下载地址,目前最高版本到spring4.3.8,留存备用:
http://maven.springframework.org/release/org/springframework/spring/