mysql5.6迁移到mariadb

最近因为开发需要,需要将后台数据库从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查询语句,终于使用索引了,查询时间也立马降了下来。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值