MySql的优化步骤
<div id="cnblogs_post_body"> MySql优化的一般步骤:
SHOW STATUS提供msyql服务器的状态信息 一般情况下,我们只需要了解以”Com”开头的指令 show session status like ‘Com%’:显示当前的连接的统计结果 show global status like ‘Com%’ :显示自数据库上次启动至今的统计结果 注:默认是session级别的 其中Com_XXX表示XXX语句所执行的次数。 另外,还有几个参数需要注意下: show status like ‘Connections’// 试图连接MySQL服务器的次数 show status like ‘Uptime’//服务器工作的时间(单位秒) show status like ‘Slow_queries’//慢查询的次数 (默认是10秒中就当做是慢查询,如下图所示)
a) 如何查询mysql的慢查询时间 Show variables like 'long_query_time'; b) 修改mysql 慢查询时间 set long_query_time=2//如果查询时间超过2秒就算作是慢查询
问题是:如何在一个项目中,找到慢查询的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=12345;
查询耗时:19s>2s,所以mysql会将该条select语句记录到慢查询日志中 SELECT * FROM order_copy WHERE id=12345的执行时间: 添加索引前:19s 添加索引后:0.08s
使用explain分析该dql语句: 会产生如下信息:
4.确定问题并采取相应的优化措施
但是索引并不是可以随便添加的,以下几种情况需牢记在心: ?select * from order_copy where id = $id ?select * from order_copy where sex=’女’ ?select * from order_copy where order_state=’未付款’ 索引的类型:
索引的使用
?添加主键(索引) ALTER TABLE 表名 ADD PRIMARY KEY(列名,..); 联合主键
相关资料: explain的使用: 转载请注明出处: (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Mysql应用Linux中使用mysqladmin extended-status配合Linux
- MYSQL教程Mysql存储引擎MyISAM的常见问题(表损坏、无法访问
- Mysql必读教会你完全搞定MySQL数据库 轻松八句话
- Mysql必读MySQL验证用户权限的方法
- java – 无法将值从列XX转换为“2012-04-05 10:20:00”到T
- Mysql应用replace MYSQL字符替换函数sql语句分享(正则判断)
- 比较SMALLINT,INTEGER和DECIMAL的性能
- 防止MySQL将隐式默认值插入非空列
- MYSQL数据库mysql 内存表基础知识
- mysql – 创建指标的顺序会影响查询优化器将选择哪个索引?