Mysql性能优化–Explain详解

EXPLAIN

mysql explain命令是查询性能优化不可缺少的一部分。

explain output columns

列名 说明
id 执行编号,标识select所属的行。如果在语句中没有子查询或者关联查询,只有唯一的select,每行都将显示1。否则,内层的select语句一般会顺序编号,对应于其在原始语句中的位置
select_type 显示本行是简单或是复杂select。如果查询有任何复杂的子查询,则最外层标记为primary(derived、Union、Union resuit)
table 访问引用哪个表(引用某个查询,如“derived3”)
partitions 匹配的分区
type 数据访问/读取操作类型(all、index、range、ref、eq_ref、const/system、NULL)。join类型
possible_keys 揭示哪一些索引可能有利于高效的查找
key 此次查询中确切使用到的索引.
key_len 显示mysql在索引里使用的字节数
ref 哪个字段或常数与key一起被使用
rows 为了找到所需的列而需要读取的行数,估算值,不精确。通过把所有rows列值相乘,可粗略估算整个查询会检查的行数
filtered 表示此查询条件所过滤的数据的百分比
Extra 额外信息,如using index、filesort等

继续阅读“Mysql性能优化–Explain详解”

MySQL 字符串字段转换 crc32 建索引提高查询效率

给字符串类型的字段建立索引效率不高,但是必须要经常查这个字段怎么建索引?比如这个字段名称是 sys_trans_id 字符串类型,那么可以建一个字段 sys_trans_id_src32 来存储 crc32 的值,并给这个字段建立索引。

crc32 是整形,在MySQL中,给整形字段建立索引效率比较高,crc32虽然不能确保唯一性,但是无碍,相同的机率也是极小,关键是可以大大减少查询的范围,给sys_trans_id_src32 这个字段建立索引,查询的时候带上 crc32 字段就可以利用到索引。

继续阅读“MySQL 字符串字段转换 crc32 建索引提高查询效率”

mysql数据库建立索引的好处和代价

说起提高数据库性能,索引是最物美价廉的东西了。不用加内存,不用改程序,不用调sql,只要执行个正确的’create index’,查询速度就可能提高百倍千倍,这可真有诱惑力。可是天下没有免费的午餐,查询速度的提高是以插入、更新、删除的速度为代价的,这些写操作,增加了大量的I/O。由于索引的存储结构不同于表的存储,一个表的索引所占空间比数据所占空间还大的情况经常发生。

这意味着我们在写数据库的时候做了很多额外的工作,而这个工作只是为了提高读的效率。因此,我们建立一个索引,必须保证这个索引不会“亏本”。

继续阅读“mysql数据库建立索引的好处和代价”

MYSQL中myisam和innodb引擎的区别

MyISAM 是MySQL中默认的存储引擎,一般来说不是有太多人关心这个东西。决定使用什么样的存储引擎是一个很tricky的事情,但是还是值我们去研究一下,这里的文章只考虑 MyISAM 和InnoDB这两个,因为这两个是最常见的。

讲讲你对mysql myisam和innodb的认识。然后你认为他们的区别在那里?为什么?

继续阅读“MYSQL中myisam和innodb引擎的区别”