【MySQL】mysql因为字符集导致left join出现Using join buffer (Block Nested Loop)

在进行SQL查询时,发现索引未被使用,即使已为表添加了所有必要的索引。经过检查,问题在于字符集不一致导致索引失效。当表的数据增长,WHERE条件筛选出的数据量过多,可能使索引利用率低于15%,从而不再有效。通过使用EXPLAIN分析,确定了问题根源。解决方法是将表的字符集转换为UTF8MB4,使用ALTER TABLE语句成功修复了这个问题。
摘要由CSDN通过智能技术生成

今天在查询一个sql的时候发现没有使用到索引

仔细看了很多遍,该加的索引都加了,还是不行

使用explain查看

索引为什么失效

  1. 隐式转换导致索引失效
  2. 随着表的增长,where条件出来的数据太多,大于15%,使得索引失效(会导致CBO计算走索引花费大于走全表)
  3. 字符集不一致导致索引失效一个utf8一个utf8mb4

我这里主要是字符集不一致,索引失效了

转换了一下字符集就成功了

ALTER TABLE user CONVERT TO CHARSET utf8mb4;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值