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

来源: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
投稿

猜你喜欢

  • python3通过qq邮箱发送邮件以及附件

    2023-05-06 12:48:27
  • python下PyGame的下载与安装过程及遇到问题

    2021-09-24 00:12:15
  • Python中try excpet BaseException(异常处理捕获)的使用

    2023-07-30 16:21:37
  • Go语言实现字符串切片赋值的方法小结

    2024-02-01 14:30:19
  • 使用pytorch完成kaggle猫狗图像识别方式

    2023-04-10 08:39:01
  • D3.js实现拓扑图的示例代码

    2024-05-09 10:20:06
  • Python详细介绍模型封装部署流程

    2023-03-27 00:49:32
  • Pip install和Conda install的使用

    2023-11-04 17:32:37
  • Python读写Json涉及到中文的处理方法

    2021-10-29 10:26:24
  • Python初识逻辑与if语句及用法大全

    2023-11-21 16:17:24
  • 详解JS深拷贝与浅拷贝

    2024-05-22 10:40:40
  • 基于python实现数组格式参数加密计算

    2021-08-20 23:29:54
  • Django实现自定义路由转换器

    2021-09-10 05:49:04
  • Python操作Redis数据库的超详细教程

    2024-01-13 04:37:30
  • vue中resetFields重置初始值不生效的原因详解

    2024-05-29 22:29:12
  • javascript手风琴下拉菜单实现代码

    2024-06-20 19:18:32
  • 如何用Python来搭建一个简单的推荐系统

    2022-07-20 22:17:33
  • 如何创建 Firefox 的 Jetpack 扩展

    2009-10-13 20:55:00
  • Python实现识别文字中的省市区并绘图

    2021-10-11 08:14:52
  • python实现ip查询示例

    2021-07-07 20:04:32
  • asp之家 网络编程 m.aspxhome.com