mysql关联表索引失效问题

本文探讨了在使用关联查询(如inner、left、right join)时,尽管关联条件已建立索引,但执行计划显示未使用索引的问题。分析发现,两表字段的字符集不一致是主要原因,并提供了通过修改表字段字符集来解决问题的方法,同时提醒在业务高峰期避免执行此操作,推荐使用pt-online-schema-change进行在线修改。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、 场景:当使用关联查询(inner 、left、right join)等进行查询时候,关联条件都已建立索引,但查看执行计划发现并未走索引。

  原因:两表字段的字符集不相同导致关联查询索引失效

  解决方案:修改表字段字符集类型,保证字符集一致,语句:alter table t1 convert to charset utf8mb4;(alter table t1 charset utf8mb4;但这是错的,这只是改了表的默认字符集,即新的字段才会使用utf8mb4,已经存在的字段仍然是utf8)

    注意事项:alter table 改字符集的操作是阻塞写的(用lock = node会报错)所以业务高峰时请不要操作,即使在业务低峰时期,大表的操作仍然建议使用pt-online-schema-change在线修改字符集

引用文章:https://blog.youkuaiyun.com/sunbocong/article/details/100558286

pt-online-schema-change使用: https://segmentfault.com/a/1190000014924677?utm_source=tag-newest

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值