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

转载于:https://www.cnblogs.com/ifmb/archive/2009/10/30/1593251.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值