动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
   数据库 → 阅读文章
  

 SQL查询的分页思路

作者来源: 
阅读 数 327 人次 , 2006-4-13 15:49:00 


 如果用一般的SELECT *  查询SQL数据库,然后用recordset进行分页的话,在返回结果很多的情况下将会是一个漫长的过程,而且很消耗内存.你可能会有感觉,用access也比SQL快.
其实我们可以只取出我们每页需要显示的记录数,这样的速度是惊人的,非常快.这里我们会用到聚集索引来快速确定我们需要取出的记录数的位置.如下面:
  if p>1 then 'p为PAGE页数
  if n="next" then'下一页
  sql="select top 26 * from song1 where  id  > "&pk&"  and contains(songtitle,'"&songname&"')"  'PK为当前页的最大ID数
  elseif n="prev" then'上一页
  sql="select top 26 * from song1 where  id  < "&previd&"  and contains(songtitle,'"&songname&"') order by id desc"'previd最小ID
  end if
else
  sql="select top 26 * from song1 where contains(songtitle,'"&songname&"')"'没有指定PAGE值,默认第一页
end if
 这里用到了全文检索,速度也是很快的,我在52万记录下测试,最快可以46MS(机器C1.7.  DDR 256M),感觉比较可以,我用like代码模糊查询页测试过,在结果集很多的情况下比全文更快,但是如果结果很少(整个表只有那么几条)将是漫长的过程,因为要对全表进行扫描!

  按上面的方法不能得出所查询结果得总记录数,这里我们可以用select count(*) 来获取记录总数,速度页还过得去,不过感觉要慢一截,特别是记录集很多得情况,不过这样占用得内存很小得.
以上是我最近搞SQL查询得心得.

 本文Tags分页  数据库  
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:SQL语法查询文档
· 下一篇:MySQL中修改密码及访问限制设置详解
· MYSQL用户root密码为弱口令又一攻击方法
· MySQL分页模型(Pagination.php)
· Oracle性能究极优化 上
· Sybase数据库技术(6)
· 从Oracle迁移到SQL Server的陷阱


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077