TOP 失效

今天在调式用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

posted @ 2009-10-30 18:24  小尹.  阅读(242)  评论(0编辑  收藏  举报