SQLServer索引优化(3):对于建组合索引的要求

SQL语句:

select count(1) as rec_count from [Delivery_Item] where ( (((DeliverySysNo <> 6564924) AND (WaybillID in ('55707745521') )) AND (IsDelete = 0)) )


组合索引(1): WaybillID、 IsDelete、 DeliverySysNo


组合索引(2): DeliverySysNo、 WaybillID、 IsDelete


组合索引(1)因为 WaybillID为不唯一值,所以数据没有重复率,可以大量筛选数据,所以要放在组合索引的第一个。

如果用了组合索引(2),因为 DeliverySysNo是个范围值,数据筛选率低,索引会进行大量的IO扫描,执行效率低。


所以建议使用组合索引(1)。



请使用浏览器的分享功能分享到微信等