CSDNMINGZI 2022-08-04 10:14 采纳率: 0%
浏览 347
已结题

sql 使用到where和groupby时建立索引结果为啥是这样,原理是什么?

优化sql的时候,由于数据量比较大,一个简单的sql但执行速度特别慢
SELECT max(id) FROM log WHERE create_date <= "2022-08-03" GROUP BY code


试了这四种索引,create_date、code、(code,create_date)、(create_date,code)

网上查是说建立(create_date,code)组合索引,毕竟先执行where再执行groupby ,explain可以看到居然只使用到组合索引中的 create_date,没有使用到code,查询速度也没有变快
结果使用(code,create_date)组合索引是最快的,只需要1秒,explain命令查看索引的两列都用到了
为什么(code,create_date)是最快的,这到底是什么原理


补充一下:
建立create_date和code的单独索引用explain看到只走了code索引
这要是组合索引(code,create_date)中也只走了code我还好理解些,偏偏组合索引(code,create_date)中两个索引都走了
而组合索引(create_date,code)中只走了create_date

  • 写回答

8条回答

报告相同问题?

问题事件

  • 系统已结题 8月12日
  • 修改了问题 8月4日
  • 修改了问题 8月4日
  • 修改了问题 8月4日
  • 展开全部

悬赏问题

  • ¥15 数学的三元一次方程求解
  • ¥20 iqoo11 如何下载安装工程模式
  • ¥15 本题的答案是不是有问题
  • ¥15 关于#r语言#的问题:(svydesign)为什么在一个大的数据集中抽取了一个小数据集
  • ¥15 C++使用Gunplot
  • ¥15 这个电路是如何实现路灯控制器的,原理是什么,怎么求解灯亮起后熄灭的时间如图?
  • ¥15 matlab数字图像处理频率域滤波
  • ¥15 在abaqus做了二维正交切削模型,给刀具添加了超声振动条件后输出切削力为什么比普通切削增大这么多
  • ¥15 ELGamal和paillier计算效率谁快?
  • ¥15 蓝桥杯单片机第十三届第一场,整点继电器吸合,5s后断开出现了问题