MSSQL SERVER 覆盖索引和复合索引的区别 MSSQL SERVER 覆盖索引和复合索引的区别 ,如题,求大神指点
执行计划里面,出现的都是 INDEX SEEK。有点迷茫 ------解决方案-------------------- 联合索引和覆盖索引有很大的区别:
覆盖索引是查询的列可以直接通过索引提取,比如只查询主键的列!或者查询联合索引的所有列或者左边开始的部分列(注意有顺序的)
而联合索引并不一定只从索引中能获取到所有的数据,这个取决于你所查询的列。比如select * from table where ××××××;的方式就不太可能是覆盖索引。因此如果你查询的列能用到联合索引,且你查询的列都能通过联合索引获取,比如你只查询联合索引所在的列或者左边开始的部分列,这就相当于覆盖索引了。通常为了让查询能用到覆盖索引,就将要查询的多列数据设置成联合索引 ------解决方案--------------------