今天在调式用ASP+ACCESS制作的征婚网站的时候 发现原本通过TOP限定的数据并没有按照自己的意愿返回 而是将所有满足where条件的数据进行全部返回
结果查找资料后 发现:
如果SQL语句同时存在where 和top 的时候,按照SQL执行的顺序会先执行where里面条件在执行top语句 如果where条件列不是合适的索引 程序执行
的是全表扫描 首先是查找符合where的所有数据,而这里的TOP形同虚设。
然而这就存在两种情况:
1. 如果我想通过where获取条件语句的一些行
这种情况可以通过先创建一个满足条件的子表 然后TOP该子表里面的一些行(不足:如果数据量是百万级别,查找起来就相对费时)
eg:select top 30 * from (select * from Table Where ********)
2. 如果我想通过TOP获取一些行
这种情况可以先通过TOP去获取一定范围的数据 然后通过判断来过滤自己想要的数据(不足:有可能通过判断发现TOP后的数据都不满足条件)
eg: select top 100 * from Table
转载于:https://www.cnblogs.com/ifmb/archive/2009/10/30/1593251.html