首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么不在另一个数据库中执行相同的查询时使用索引呢?

为什么不在另一个数据库中执行相同的查询时使用索引呢?
EN

Stack Overflow用户
提问于 2019-04-25 02:00:36
回答 1查看 173关注 0票数 0

我有两个数据库。一个是prod数据库(mysql),另一个是开发数据库(mysql)。

使用explain键时,开发数据库使用索引,而prod数据库不工作。

同一查询同一数据库(开发数据库是prod的副本)相同的索引.

所以我检查了索引,“显示索引”.

但指数一样。

解释开发数据库的结果

解释prod数据库的结果

我希望'p‘表使用索引'idx_payment_tb’

EN

回答 1

Stack Overflow用户

发布于 2019-04-30 01:48:59

当优化器选择不使用索引时,这通常是出于一个很好的原因--即数据分布是这样的,因此使用索引实际上要慢一些。

请提供SHOW CREATE TABLEEXPLAIN SELECT作为文本,而不是图像。优化器可能会回避索引,原因有很多;我们可能会告诉您这次使用的是哪个原因。

  • 如果这是一张很小的桌子,那为什么还要考虑指数呢?
  • 如果在表中使用的键“很多”(在dev和prod之间可能有所不同),则索引和数据之间来回跳的速度可能会慢一些。
  • 这两台机器之间的统计数据可能有所不同。
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55840801

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档