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)。