位置: 编程技术 - 正文

MySql的优化步骤介绍(推荐)(mysql的20条优化方法)

编辑:rootadmin

推荐整理分享MySql的优化步骤介绍(推荐)(mysql的20条优化方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql的优化方案,mysql优化的几种方法,mysql优化十大技巧,mysql语句如何优化,mysql优化的几种方法,mysql 优化口诀,mysql优化的几种方法,mysql的优化方案,内容如对您有帮助,希望把文章链接给更多的朋友!

MySql优化的一般步骤:

1.通过show status 命令了解各种sql的执行效率

SHOW STATUS提供msyql服务器的状态信息

一般情况下,我们只需要了解以”Com”开头的指令

show session status like ‘Com%':显示当前的连接的统计结果

show global status like ‘Com%' :显示自数据库上次启动至今的统计结果

注:默认是session级别的

其中Com_XXX表示XXX语句所执行的次数。

重点注意:Com_select,Com_insert,Com_update,Com_delete通过这几个参数,可以容易地了解到当前数据库的应用是以插

入更新为主还是以查询操作为主,以及各类的SQL大致的执行比例是多少。

另外,还有几个参数需要注意下:

show status like ‘Connections'// 试图连接MySQL服务器的次数

show status like ‘Uptime'//服务器工作的时间(单位秒)

show status like ‘Slow_queries'//慢查询的次数 (默认是秒中就当做是慢查询,如下图所示)

a) 如何查询mysql的慢查询时间

Show variables like 'long_query_time';

b) 修改mysql 慢查询时间

set long_query_time=2//如果查询时间超过2秒就算作是慢查询

2. 定位执行效率较低的SQL语句(dql出现问题的概率较dml的大)

问题是:如何在一个项目中,找到慢查询的select语句?

答案:mysql支持把慢查询语句记录到日志文件中。程序员需要修改php.ini的配置文件,默认情况下,慢查询记录是不开启的。

开启慢查询记录的步骤:

打开 my.ini ,找到 [mysqld] 在其下面添加

long_query_time = 2

log-slow-queries = D:/mysql/logs/slow.log #设置把日志写在那里,可以为空,系统会给一个缺省的文件

例子:我们数据表中有1千万条的数据量

DQL语句:SELECT * FROM order_copy WHERE id=;

查询耗时:s>2s,所以mysql会将该条select语句记录到慢查询日志中

SELECT * FROM order_copy WHERE id=的执行时间:

添加索引前:s

添加索引后:0.s

MySql的优化步骤介绍(推荐)(mysql的20条优化方法)

3.通过explain分析低效率的SQL语句的执行情况

使用explain分析该dql语句:

EXPLAIN SELECT * FROM order_copy WHERE id=

会产生如下信息:

select_type:表示查询的类型。

table:输出结果集的表

type:表示表的连接类型(system和const为佳)

possible_keys:表示查询时,可能使用的索引

key:表示实际使用的索引

key_len:索引字段的长度

rows:扫描的行数

Extra:执行情况的描述和说明

注意:要尽量避免让type的结果为all,extra的结果为:using filesort

4.确定问题并采取相应的优化措施

常用的优化措施是添加索引。添加索引,我们不用加内存,不用改程序,不用调sql,只要执行个正确的'create index',查询速度就可能提高百倍千倍。但是天下没有免费的午餐,查询速度的提高是以插入、更新、删除的速度为代价的,这些写操作,增加了大量的I/O。

例如:给字段id添加索引:

ALTER TABLE order_copy ADD PRIMARY KEY(id)

给1千万的数据添加primary key 需要耗时: 秒(7分钟)

EXPLAIN SELECT * FROM order_copy WHERE id=

正是因为给id添加了索引,才使得rows的结果为1

但是索引并不是可以随便添加的,以下几种情况需牢记在心:

较频繁的作为查询条件字段应该创建索引

select * from order_copy where id = $id

唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件

select * from order_copy where sex='女'

更新非常频繁的字段不适合创建索引

select * from order_copy where order_state='未付款'

不会出现在WHERE子句中字段不该创建索引

索引的类型:

PRIMARY 索引 => 在主键上自动创建INDEX 索引 => 就是普通索引UNIQUE 索引 => 相当于INDEX + UniqueFULLTEXT => 只在MYISAM 存储引擎支持, 目的是全文索引,在内容系统中用的多, 在全英文网站用多(英文词独立). 中文数据不常用,意义不大 国内全文索引通常 使用 sphinx 来完成.

索引的使用

建立索引 create [UNIQUE|FULLTEXT] index index_name on tbl_name (col_name [(length)] [ASC | DESC] , …..);alter table table_name ADD INDEX [index_name] (index_col_name,...)

添加主键(索引) ALTER TABLE 表名 ADD PRIMARY KEY(列名,..); 联合主键

删除索引 DROP INDEX index_name ON tbl_name;alter table table_name drop index index_name;删除主键(索引)比较特别: alter table t_b drop primary key;查询索引(均可) show index from table_name;show keys from table_name;desc table_Name;

标签: mysql的20条优化方法

本文链接地址:https://www.jiuchutong.com/biancheng/347581.html 转载请保留说明!

上一篇:Windows下MySQL安装配置方法图文教程(windows下mysql安装配置教程)

下一篇:mysql 5.7.10 安装配置方法图文教程(mysql5.7.29安装)

  • 长期股权投资的入账价值怎么算
  • 核定征收企业所得税率是多少
  • 解除劳动一次性补偿金怎么记账
  • 取得的高速公路发票可以抵扣吗
  • 代理记账公司账本
  • 印花税申报怎么采集
  • 查验发票会显示名字吗
  • 年报资产总额是期末余额吗
  • 企业出包工程预付的工程款
  • 发票后面附清单明细能导出吗
  • 小型企业利润表
  • 注册资本余额为100万亿元
  • 折旧已经计提完的固定资产如何盘点
  • 认缴出资股权转让的法律责任
  • 事业单位取得了应税收入如何纳税?
  • 固定资产原值减少账务处理
  • 购买毛巾的费用是多少
  • 营改增后发票上必须要开具税收分类编码吗?
  • 增值税税负率行业标准2022年
  • 简易计税核算方法有哪些
  • 误餐补助需要发票做账吗
  • 6种个人所得税违规手段,财务人再小心别跳坑!
  • 7月1日发票新规定
  • 糖类计算公式
  • 怎么查询发票是否已认证
  • 个体工商户生产经营所得税税率表2021
  • 股权转让的公允价值
  • 客户付货款给我们公司备注往来结算款
  • 盈余公积意思大白话解释
  • 车提折旧会计分录
  • 租车费增值税专用发票
  • 印花税查账征收和核定征收计算
  • 已认证的进项税额转出怎么做账务处理
  • 当月交当月社保费会计分录
  • 摊销房租费如何做账
  • 隐藏登录界面的软件
  • 电脑打不了字只有拼音,按哪个键
  • 如何增加税务稽查信息
  • 不确认收入要结转成本吗
  • 存货损失账务处理新规定
  • css flaot
  • 阿尔卑斯山环保
  • 资产负债表中其他综合收益怎么填
  • bootstrap-
  • flex的作用及设置
  • 每个开发人员都有编制吗
  • yii框架教程
  • 资产负债表和利润表的勾稽关系
  • 培训费开票属于哪个征收明目
  • 邮电通信企业业务收入包括哪些内容?
  • T-SQL语句修改数据表属性
  • 民办非企业单位是私立还是公立
  • 账实核对是指各种财产物资与债权债务的账面余额
  • 汽车销售和租赁业务描述
  • 债务重组的方式不包括借新债还旧债
  • 个体户如何做账?
  • 学历教育服务增值税
  • 按次缴纳的个人所得税
  • 抵货款怎么做账
  • 报销单会计分录怎么写
  • 高新技术企业一定是先进制造业吗
  • 无进项发票开具销项发票
  • 暂估入账后费用怎么做账
  • 防伪税控费用抵税分录
  • 一家公司一定要有一个社保吗
  • mysql5.7最新版
  • win8系统的运行在哪里打开
  • 如何知道文件的解压密码
  • linux kill-15
  • win10脱机使用
  • WIN7系统屏幕亮度哪里设置
  • jquery直接执行
  • 教你在heroku云平台上部署Node.js应用
  • jquery时间格式
  • 文本框css关闭输入框
  • JavaScript Array对象详解
  • django admin form
  • 从国外进口到国内销售的商品
  • 河南税务局官网手机版
  • 交完车船税后地税局都给什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设