ALTER view [dbo].[V_EXP_Freebeer] as
select top 100 PERCENT a.ContractNo,a.PayerID,a.PayerName,q.YearMonth,b.SKUID,C.CProduct,f.Volume
from bd_contract_main a
.
.
.
order by a.ContractID,b.SKUID,q.YearMonth
原意是选出符合“where 条件”的记录集里的“前100%” 条
但是,对于该SQL语句,由于语句里同时存在where和top语句的,并且where条件列不是合适的索引,程序执行的是全表扫描,首先是查找符合where条件的记录, 而这里的top限制形同虚设。如果全表是百万级别以上的数据表,那么就这么一个简单的判断,就有可能拖垮数据库。
所以需要先把符合“where条件”的记录,用一个子查询筛选出来,再在筛选结果集里选top30。
因为SQL规则规定,如果子查询里,有order ...,就必须有TOP,所以就用SELECT TOP 100 PERCENT来限定,top 100 percent是为了保证筛选出所有符合条件的数据条目。