舷Kelvin 2023-01-04 14:50 采纳率: 61.5%
浏览 38
已结题

是否可以为了覆盖索引而在联合索引中增加列?

是否可以为了覆盖索引而在联合索引中增加列?

比如常用一个查询语句类似

select c1,c2,c3 from tt where c1='a' and c2='b'

我们在设计联合索引的时候是三列都放进去还是只放where后的两列?
个人感觉,都放进的好处是不用回表了,能够索引覆盖,c3虽然不是查询条件但也等于空间换时间了能够有效提高查询效率。
但又好像在哪儿看到过,说查询结果列(仅出现在select后的列)不应该加入到联合索引中。所以问问各位一般怎么处理?

  • 写回答

1条回答 默认 最新

  • 心寒丶 全栈领域优质创作者 2023-01-04 15:01
    关注

    加c1,c2就行了,两个等号筛选的,联合索引,单个索引都能触发

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 1月12日
  • 已采纳回答 1月4日
  • 创建了问题 1月4日

悬赏问题

  • ¥15 在不同的执行界面调用同一个页面
  • ¥20 基于51单片机的数字频率计
  • ¥50 M3T长焦相机如何标定以及正射影像拼接问题
  • ¥15 keepalived的虚拟VIP地址 ping -s 发包测试,只能通过1472字节以下的数据包(相关搜索:静态路由)
  • ¥20 关于#stm32#的问题:STM32串口发送问题,偶校验(even),发送5A 41 FB 20.烧录程序后发现串口助手读到的是5A 41 7B A0
  • ¥15 C++map释放不掉
  • ¥15 Mabatis查询数据
  • ¥15 想知道lingo目标函数中求和公式上标是变量情况如何求解
  • ¥15 关于E22-400T22S的LORA模块的通信问题
  • ¥15 求用二阶有源低通滤波将3khz方波转为正弦波的电路