Mysql数据库:记一次关联查询时,数据量只有三十万,本地查询时间为3.664s,而去阿里云的mysql查询需要超过10min的情况及处理方式

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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值