如何解决mysql left join 查询不走索引的问题(mysql,编程语言)

时间:2024-05-03 17:27:46 作者 : 石家庄SEO 分类 : 编程语言
  • TAG :

希望大家仔细阅读,能够学有所成!

前言

本地有两张表 alarm闹钟表和alarm_order闹钟订单表
在alarm_order订单表中有alarm_id建立了索引,但是发现在left join查询的时候没有走索引查询,使用了全文搜索

如何解决mysql left join 查询不走索引的问题

问题分析

乍一看,sql语句似乎并没有问题

1、首先,来观察下两张表的字符类型是否相同

发现两张表的字符类型确实不一样,随后把表1改为utf8,再次查询发现依旧不起作用

2、最后发现可能是alarm_order表中的alarm_id的基数太小了,mysql判断全文搜索速度要快,则进行全文搜索。后来发现确实是这个问题

解决办法

mysql在一个表如果索引基数过小的情况下默认会走全文搜索,所以对于表业务量过大但是索引字段基本上为同一数据或null的情况 还是需要在sql中写死强制索引
在sql中使用强制索引解决办法 left join 后添加 force indes(alarm_id)
因为业务数据的关系,我这边alarm_id的基数确实就是很小,为了走索引查询,直接加上强制索引查询

如何解决mysql left join 查询不走索引的问题

再次测试,问题解决了!!~~

本文:如何解决mysql left join 查询不走索引的问题的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:身份证号码归属地数据库的实现方法下一篇:

16 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18