Mysql数据库:记一次数据量只有三十万左右,对表直接关联查询时,本地查询时间为3.664s,但阿里云的mysql查询需要超过10min的情况及解决方案

一、问题及解决方法

 只有在阿里云的MySQL执行sql时才会出现,本地未出现该问题   

考虑过的原因:
1. 未建立索引:explain + sql语句;第一想法就是未使用索引,但是本地库和阿里云的数据差不多,总共才三十多万的数据,即使全表查能用那么长时间吗?排除。
2. 字段编码不一致: SHOW full COLUMNS FROM table_name;编码方式相同,排除。
3. 考虑未加入关联查询时,sql语句执行速度还可以,并且只要关联表一个字段的数据,不用关联表去做筛选;那么可以在主表数据较多时,先对主表进行数据筛选过滤,再去进行关联查询:select ss.*,a.column0 from(select column1, column2,column3... from table_name + 筛选条件)ss left join join_table_name a on a.column=ss.column1

解决方法其实很简单,就是先对主表数据进行筛选,再做关联查询 ,但是有时候脑袋就是绕不出这个弯,记一笔。

更多推荐