欢迎投稿

今日深度:

mysql5.6迁移到mariadb,mysql5.6mariadb

mysql5.6迁移到mariadb,mysql5.6mariadb


最近因为开发需要,需要将后台数据库从mysql5.6像mariadb迁移,选择的mariadb版本是10.0.18-MariaDB-log。

为了图省事,直接将mysql5.6停止,然后拷贝数据库目录,数据库表引擎都是myisam。但是启动mariadb之后,发现了一个慢查询。迁移之前,该查询是极快的,仅仅需要不到10ms,但是迁移后达到了惊人的600ms。explain了该查询语句后,发现type竟是ALL,没有利用任何索引,之前都是ref,使用了创建的联合索引。

显然,mariadb并没有利用建立的索引,很是诡异。使用show index查看后,发现迁移到mariadb后,Cardinality列的值变成NULL,迁移之前是有数值的。于是,又新建了一个所索引,这个新建的索引比已有的联合索引少一列。然后,写了一个查询语句强制指定使用新建的这个索引,但是explain后发现,还是没有任何效果,也就是mariadb仍然视而不见这个索引。再次使用show index时,发现新建的索引Cardinality列的值还是NULL。

于是,尝试了一下,把所有联合索引均删除,然后再新建。使用show index命令查看时,Cardinality列终于有数字了。再次explain原来的慢sql查询语句,终于使用索引了,查询时间也立马降了下来。


www.htsjk.Com true http://www.htsjk.com/mariadb/29140.html NewsArticle mysql5.6迁移到mariadb,mysql5.6mariadb 最近因为开发需要,需要将后台数据库从mysql5.6像mariadb迁移,选择的mariadb版本是10.0.18-MariaDB-log。 为了图省事,直接将mysql5.6停止,然后拷贝数据库目录...
相关文章
    暂无相关文章
评论暂时关闭