mysql数据库,索引字符集不一致,slowsql慢查询,接口超时问题

mysql数据库,slowsql慢查询导致接口超时问题

现象:日志中有slowsql,在数据库中执行也查询不出来,接口超时加载不出来。多表关联查询,有索引但在生产环境没用上。

分析过程:
1.查看执行计划, explain。在开发环境时间很快,在生产环境超时,索引失效。关联查询,有几张表10万级数据量,join取笛卡尔集,查询的数据量很大。
2.优化了sql,开发环境从10秒左右优化到0.几秒。生产环境还是超时。
3.由于没有其他报错日志,还是怀疑数据库端的问题。因为各个环境一致的。首先排除数据库版本问题。
4.排查是否锁表了,show OPEN TABLES where In_use>0。如果有,见5
5.查询进程,show processlist。查询到被锁的进程后kill掉

原因:
关联查询的索引,字符集和排序字符集不一致,导致索引失效。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值