mysql数据库优化一般流程
2018-01-03 13:55
176 查看
一: 通过Show status 查看数据库状态
三:通过explain分析效率低的sql语句的执行情况
注意:要尽量避免让type的结果为all,extra的结果为:using filesort
四: 确定问题并采取优化措施
- -查看MySQL本次启动后的运行时间(单位:秒) show status like 'uptime'; - -查看select语句的执行数 show [global] status like 'com_select'; - -查看insert语句的执行数 show [global] status like 'com_insert'; - -查看update语句的执行数 show [global] status like 'com_update'; - -查看delete语句的执行数 show [global] status like 'com_delete'; - -查看试图连接到MySQL(不管是否连接成功)的连接数 show status like 'connections'; - -查看线程缓存内的线程的数量。 show status like 'threads_cached'; - -查看当前打开的连接的数量。 show status like 'threads_connected'; - -查看当前打开的连接的数量。 show status like 'threads_connected'; - -查看创建用来处理连接的线程数。如果Threads_created较大,你可能要增加thread_cache_size值。 show status like 'threads_created'; - -查看激活的(非睡眠状态)线程数。 show status like 'threads_running'; - -查看立即获得的表的锁的次数。 show status like 'table_locks_immediate'; - -查看不能立即获得的表的锁的次数。如果该值较高,并且有性能问题,你应首先优化查询,然后拆分表或使用复制。 show status like 'table_locks_waited'; - -查看创建时间超过slow_launch_time秒的线程数。 show status like 'slow_launch_threads'; - -查看查询时间超过long_query_time秒的查询的个数。 show status like 'slow_queries';二:定位执行效率较低的SQL语句
问题是:如何在一个项目中,找到慢查询的select语句? 答案:mysql支持把慢查询语句记录到日志文件中。程序员需要修改php.ini的配置文件,默认情况下,慢查询记录是不开启的。 开启慢查询记录的步骤: 打开 my.ini ,找到 [mysqld] 在其下面添加 long_query_time = 2 log-slow-queries = D:/mysql/logs/slow.log #设置把日志写在那里,可以为空,系统会给一个缺省的文件
三:通过explain分析效率低的sql语句的执行情况
EXPLAIN SELECT * FROM order_copy WHERE id=12345 会产生如下信息: select_type: 表示查询的类型。 table: 输出结果集的表 type: 表示表的连接类型(system和const为佳) possible_keys: 表示查询时,可能使用的索引 key: 表示实际使用的索引 key_len: 索引字段的长度 rows: 扫描的行数 Extra: 执行情况的描述和说明
注意:要尽量避免让type的结果为all,extra的结果为:using filesort
四: 确定问题并采取优化措施
常用的优化措施是添加索引。添加索引,我们不用加内存,不用改程序,不用调sql,只要执行个正确的’create index’,查询速度就可能提高百倍千倍。但是天下没有免费的午餐,查询速度的提高是以插入、更新、删除的速度为代价的,这些写操作,增加了大量的I/O。 例如:给字段id添加索引: 但是索引并不是可以随便添加的,以下几种情况需牢记在心: 1) 较频繁的作为查询条件字段应该创建索引 select * from order_copy where id = $id 2) 唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件 select * from order_copy where sex=’女’ 3) 更新非常频繁的字段不适合创建索引 select * from order_copy where order_state=’未付款’ 4) 不会出现在WHERE子句中字段不该创建索引 索引的类型: PRIMARY 索引 => 在主键上自动创建 INDEX 索引 => 就是普通索引 UNIQUE 索引 => 相当于INDEX + Unique FULLTEXT => 只在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;
相关文章推荐
- SQL优化【基础08】 - 耗能SQL分析一般流程思路
- JDBC一般流程及优化过程
- Google优化一般流程和一些常识
- Node.js使用MySQL数据库的一般流程
- Hive创建表一般流程(优化)
- MySQL数据库高并发优化配置
- MySQL数据库性能优化-利用sql执行计划预先查看执行性能(五)
- 转载:30多条mysql数据库优化方法,千万级数据库记录查询轻松解决
- 测试流程优化
- mysql数据库优化方向
- MySQL数据库的优化
- MySQL数据库性能优化之存储引擎选择
- MySQL数据库优化推荐的编译安装参数小结
- MySQL数据库的优化(上)单机MySQL数据库的优化
- MySQL数据库性能优化
- mysql数据库查询优化
- MySQL数据库优化总结
- MySQL数据库结构优化
- 运维角度浅谈Mysql数据库优化