数据库查询的分页优化技巧

来源:asp之家 时间:2009-05-17 10:31:00 

分页浏览功能是常见的Web应用功能,对于MySQL数据库来说可以很轻松的使用limit语句实现分页,而对于SQL Server数据库来说,常见的方法是使用数据集本身的游标实现分页,这种方法对于少量数据来说没什么问题,但是对于稍大一点的数据量,例如几十万条数据,则查询速度会降低很多,这里我介绍一种常用的技巧,只要简单的重新构造一下查询SQL语句,就能大幅提高查询性能的方法。

在分页算法中,影响查询速度的关键因素在于返回数据集的大小,我们先在数据表中设置一个名为id的主键,数值为自增量的整数,然后通过重构查询SQL语句,就可以实现SQL查询的优化,重构的SQL如下所示


以下为引用的内容:

select top 页大小 *
from table1
where id<=
      (select min (id) from
      (select top ((页码-1)*页大小) id from table1 order by id desc) as T
       )   
order by id desc


下面的JSP演示代码中,intPageSize为页大小,intPage为页码,id为主键,演示了操作一个t_Product表,并加入各类查询条件之后的重构SQL的主要语句,经过实际调试,经过这样简单优化后的SQL查询速度远远高于优化前的查询速度。


以下为引用的内容:

String sql=" from t_Product where 1=1 and ";
String ProductName = request.getParameter("ProductName");
if (ProductName!=null) sql=sql+"ProductName like '%" + ProductName + "%' and " ;
sql=sql.substring(0,sql.length()-4);  // 去掉尾部的 and 字符串
sql="select top " + String.valueOf(intPageSize) + " *" +sql+" and id <=(select min(id) from (select top " +  String.valueOf(intPage*intPageSize) + " id " + sql + " order by id desc) as T) "; //通过子查询加快速度
sql=sql+" order by id desc ";



标签:数据库,查询,分页,优化技巧
0
投稿

猜你喜欢

  • 如何获取浏览器的更多信息?

    2009-11-23 20:48:00
  • 怎么样在网页上读取远程xml的数据

    2008-10-10 17:43:00
  • 由浅到深了解JavaScript类

    2008-06-16 13:20:00
  • VBScript中的eval()函数

    2008-04-09 13:41:00
  • windows7下调试ASP+ACCESS错误“未找到提供程序 该程序可能未正确安装”解决办法

    2009-12-26 18:35:00
  • Oracle DBA常用语句第1/2页

    2009-08-08 22:38:00
  • 用Dreamweaver MX实现网站批量更新

    2009-09-13 18:39:00
  • MySQL查询不含周末的五天前的日期

    2008-11-11 12:28:00
  • seo网站如何实现301跳转?

    2010-01-15 12:59:00
  • 使用线框图来简化你的产品设计流程

    2011-06-10 13:10:00
  • jQuery在去除缓存数据的一个失误

    2009-12-14 20:40:00
  • 怎么让按钮更容易被点击

    2007-08-22 09:07:00
  • SQL Server 2000里的数据类型

    2011-06-11 14:07:00
  • Dreamweaver打造多彩文字链接

    2007-11-11 18:59:00
  • 如何在社区建立一个寻呼台?

    2009-11-08 18:59:00
  • Opera下的max-width BUG

    2010-06-26 12:51:00
  • 如何动态产生变量?

    2009-11-18 16:33:00
  • 利用sort()和Math.random()实现元素的随机排列

    2010-10-19 12:42:00
  • HTML中小meta的大作用

    2008-04-25 22:40:00
  • 使用AJAX的一个简单的例子

    2007-09-21 17:55:00
  • asp之家 网络编程 m.aspxhome.com