jsp+mysql分页技巧:巧用limit 进行分页查询

2023-11-06

发现问题:

 

 

今天检查web程序,浏览“彩信xxxx日志”时,突然发现该web程序中不能浏览了,出错了,如下:
500 Servlet Exception

java.lang.OutOfMemoryError

Resin- 3.0.6 (built Tue, 20 Jan 2004 09:46:57 PST)

查找原因:

怎么会呢?一直运行好好的程序,开始以为程序更新上传时弄错了,检查了多次没有发现代码问题,后来逐句调试,终于找到了原因:问题出在这里

sql="select * from MMS_Chat_MsgLog where 1=1 order by ID";

prepStmt=conn.prepareStatement(sql,ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);

rs = prepStmt.executeQuery();

我这个页面是用jsp从库中查数据然后在前台分页显示,先返回ResultSet记录集,rs.last();rs.getRow();得到记录总数,然后根据查询页次和页面大小,使用rs.absolute(posion);语句设置记录游标的位置,把记录显示到页面。

起初数据库中记录并不多,返回rs没有问题,但是随着记录增多(查了一下有20多万条吧)这样再返回rs就出问题了,即使不出错返回速度也是很慢,因为select * from 要缓存所有记录。

       我把sql改了一下,="select * from MMS_Chat_MsgLog where 1=1 order by ID limit 10";再次执行,OK了,页面没有报错。确定了以上就是问题原因,就是返回记录集太多,机器不干了。从网上查询了一些关于jsp分页技术介绍,也是这么说的。

解决办法:

       如果按照网上一些例子修改起来非常麻烦,我不想对原来的代码进行大动手术。突然想到了,可以利用mysqlsql语法中limit来完成这个任务。Limit 有两个参数 (语法:limit 参数1,参数2)参数1是记录指针位置,参数2是返回记录数。呵呵,唯一要改得地方就是:得到记录总数的方法 原来的sql后加上limit语句就OK 了。

改造如下:

//分页显示(页次信息从用户确定页面获取)

int pageno=1;//页次-默认第一页

int pagesize=20;//页面显示记录数

int pagecount=1;//页数默认1

int rscount=0;//记录总数

String pagenoStr=request.getParameter("pageno")==null?"1":request.getParameter("pageno");

String pagesizeStr=request.getParameter("pagesize")==null?String.valueOf(pagesize):request.getParameter("pagesize");;

try{

       pageno=Integer.parseInt(pagenoStr);

       pagesize=Integer.parseInt(pagesizeStr);

}

catch(Exception e)

{

       pageno=1;

       pagesize=20;

       e.printStackTrace();

       out.println("<br>[mms_income.jsp] find error0:"+e.toString());

}

//查询用户信息

String sql="";  //说明:sql是根据条件动态产生的半句sql

       if(MsgFlag.equals("")){

              sql="from MMS_Chat_MsgLog where 1=1";

       }else{

              sql="from MMS_Chat_MsgLog where 1=1 and MsgFlag="+MsgFlag+"";

       }

       if(!UserMobile.equals("")){

              sql=sql+" and UserMobile='"+UserMobile+"'";

       }

       sql=sql+" order by ID";

 

 

String sqlTmp="select count(*) "+sql;   rs = stmt.executeQuery(sqlTmp);

rs.next();

int lastRow=rs.getInt(1);

rs.close();

//原来的方法注释掉了

//rs.last();

//int lastRow=rs.getRow();//获取最后一行的行号

 

 

这样轻松的到了记录数,下面就很简单了

//计算分页后的总页数

      pagecount = (lastRow%pagesize==0)?(lastRow/pagesize):(lastRow/pagesize+1);

      rscount=lastRow;

      if(pageno>=pagecount)pageno=pagecount;

      int curtRsCount=0;

      if(lastRow!=0)

         {

          int posion=(pageno-1)*pagesize+1;

//如果要显示第pageno页,那么游标应移到posion的位置

          sql="select * "+sql+" limit "+posion+","+pagesize; //嘿嘿,这句话是新改造的

          rs=stmt.executeQuery(sql);

      }

//下面就是显示记录的语句了。

while(rs.next())

{

//显示记录信息到页面

}

 

 

显示页次:

<script language=javascript>

function ChangePage(){

       document.Form1.pageno.value=Form2.pagenoTmp.value;

       Form1.submit();

}

</script>

<form method="POST" action="" id=Form2 name=Form2>

<!--页次信息--Begin-->

<b><%=pagecount%>页,共<%=rscount%>条,每页<%=pagesize%>条;目前显示第<%=pageno%>页。</b>

<br>

<%

int pagestart=1;

int pagestop=1;

 

 

pagestart=pageno-5<1?1:pageno-5;

pagestop=pageno+5>pagecount?pagecount:pageno+5;

 

 

for(int ix=pagestart;ix<=pagestop;ix++){%>

       <a href=?UserMobile=<%=UserMobile%>&MsgFlag=<%=MsgFlag%>&pageno=<%=ix%>><%if(ix==pageno){%><font color=red size=3><b><%=ix%></b></font><%}

              else{%><%=ix%><%}%></a>&nbsp;

<%}%>

<!--页次信息--End-->

       转到第<input type="text" name="pagenoTmp" size="7" value="<%=pageno%>"><input type="button" value="GO" name="B3" οnclick="ChangePage()">

</form>

 

 

 

 

以上只是jsp+mysql 进行分页的应用,至于其他数据库(Oracle,SQLServer),如果用原始的分页方法中计算(返回记录集跳到记录尾获得记录数)当记录数据量大时,也会出现类似问题。

可参考其他方法:

解决MVC下分页显示的问题:

http://www.pconline.com.cn/pcedu/empolder/wz/jsp/0507/661142.html

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

jsp+mysql分页技巧:巧用limit 进行分页查询 的相关文章

  • 在两个以上的表上使用内联接删除查询

    我想使用两个以上表上的内联接从表中删除记录 假设我有表 A B C D 其中 A 的 pk 在所有其他提到的表中共享 然后如何编写删除查询以使用表 B 和 A 上的内联接从表 D 中删除记录 因为条件是从这两个表中获取的 我需要从 DB2
  • 从 Visual Studio 调试 SQL Server 2005 中的存储过程?

    我在这里和其他地方看到很多令人沮丧的问题 但没有明确的答案 我试图让存储过程进行调试 但没有成功 客户端 VS2005或VS2008 两者都不起作用 当我从存储过程上下文菜单中选择 步入存储过程 时 我在调试窗口中看到 已被用户取消 这就是
  • mysql变量赋值:如何强制赋值顺序?

    由于mysql是一种声明性语言 我找不到强制赋值变量顺序的方法 采取这个查询 SET v1 0 SET v2 0 SELECT v1 v2 FROM MyTable table WHERE v1 v2 is not null AND v2
  • 使用 JOIN 和 UNION 合并不同表中的记录

    我需要创建一个查询来组合两个表中的数据 我认为可能是 JOIN 和 UNION 的组合 在此示例中 我需要列出状态处于活动状态的所有姓名 仅一次 并将他们的葡萄酒 苏打水 晚餐 甜点和水果偏好组合起来 按姓名排序 我不确定单独的 JOIN
  • 没有 DateAdd() 的 SSIS 表达式前一个日期

    目前正在开发一个包 它将表达式从先前的日期传递到文件名 我当前的代码如下作为字符串变量 DT WSTR 20 DATEPART YYYY Dateadd DD 1 dateadd MM datediff MM DT DATE 1900 01
  • 将 SQL 中的数据存储在数组中

    我正在尝试将 sql 数据库中的数据存储到数组中 目前我有这个 query mysql query SELECT FROM InspEmail WHERE Company LIKE company while row mysql fetch
  • 删除 SQL Server 上的所有扩展属性

    如何以可编写脚本的方式删除 SQL Server 上的所有扩展属性 如果您想要一个能够一次性删除所有扩展属性的脚本 请使用 Jamie Thomson 创建的脚本 该脚本将为所有扩展属性生成删除 您可以从这里下载article http s
  • 对 SQL Server 2005 结果进行分页

    如何在 SQL Server 2005 中对结果进行分页 我在 SQL Server 2000 中尝试过 但没有可靠的方法来做到这一点 我现在想知道SQL Server 2005是否有任何内置方法 分页的意思是 例如 如果我按用户名列出用户
  • 左连接,左表中没有重复行

    请看下面的查询 tbl 目录 Content Id Content Title Content Text 10002 New case Study New case Study 10003 New case Study New case S
  • SimpleSAMLPHP 重定向循环

    我们正在尝试使用自定义 mysql 数据库设置 sso 但它在以下两个请求之间进入无限循环 POST http 192 168 0 15 simplesaml module php core loginuserpass php 设置Cook
  • SQL限制数据库中的最小值和最大值

    CREATE TABLE TBL CD CDnr int identity 1 1 CDTitel nvarchar 80 NOT NULL CDduur int CDprijs smallmoney 所以我正在创建这个表 有什么方法可以将
  • 获取 SQL 表上未使用的唯一值

    我有一个表 其中有一列描述数字 ID 该 ID 对于所有行都是唯一的 但它不是主键 数字 ID 是有限的 假设答案可以是从 1 到 10 SELECT ID FROM TABLE ID 1 2 5 我必须 通过 UI 向用户呈现未使用的值
  • 获取SQL中前2个特殊字符之间的字符

    我有数据在sql 只是要注意 SQL STudio is the IDE like data a 10 b c a 1 b c 我想获取前两个符号之间的数据 Output 10 1 这就是我的方法 SELECT CAST
  • 对时间序列数据重新采样

    我有一个以毫秒为单位的时间序列列表 我想对时间序列进行重新采样并对组应用平均值 我如何在 Postgres 中实现它 重新采样 是指聚合一秒或一分钟内的所有时间戳 一秒或一分钟内的所有行形成一组 表结构 date x y z Use dat
  • 如何将另一列的整数值添加到日期列?

    我试图将整数添加到日期 但出现以下错误 1064 你的 SQL 语法有错误 检查与您的 MySQL 服务器版本相对应的手册 了解在第 6 行的 wp OrderDate INTERVAL WPProduct Duration DAY AS
  • 在 MySQL 中搜索多个单词

    我使用 HTML 表单来允许用户查找数据库表中的条目
  • 如何获取mysql中一条记录的大小

    如果表包含 TEXT 或 BLOB 类型的字段 如何获取 MySql 中记录的大小 是否可以使用sql语句获取记录或表的大小 要计算字符串或 blob 的大小 以字节为单位 请使用LENGTH YourColumn http dev mys
  • 更新查询时 ios 中出现“数据库锁定”错误

    我正在使用下面的代码更新查询 using sqlite 但我越来越 database is locked error 我尝试搜索一些 SO 链接 建议关闭数据库 但我再次执行此操作时遇到相同的错误 我已经提到过代码中出现错误的地方 cons
  • 使用 GROUP 和 SUM 的 LINQ 查询

    请帮助我了解如何使用带有 GROUP 和 SUM 的 LINQ 进行查询 Query the database IEnumerable
  • 我的数据库有错误

    创建表时如下 create table Ticket ticket id integer not null primary key AirlineName varchar not null CustomerName varchar from

随机推荐

  • Web API: URL.createObjectURL()实践

    1 问题 URL createObjectURL的介绍如下 The URL createObjectURL static method creates a DOMString containing a URL representing th
  • 图形学数学基础之1D采样分布计算方法Inverse Method

    作者 i dovelemon 日期 2017 09 04 来源 CSDN 主题 Rendering Equation Probability Density Function Cumulative Density Function 引言 前
  • Android开发中Javassist的妙用

    Javassist Java字节码以二进制的形式存储在 class文件中 每一个class文件包含一个Java类或接口 Javassist框架就是一个用来处理Java字节码的类库 它可以在一个已经编译好的类中添加新的方法 或者修改已有的方法
  • pytorch 下载

    pytorch 下载 使用anconda 直接下载pytorch的朋友应该是知道pytorch是个啥的 所以直接上教程 anconda下载 anconda是一个用于下载和管理python依赖包和环境的一个工具 下载详情可以去看这篇文章 an
  • VMware虚拟机nat模式连不上网

    我的虚拟机总是各种连不上网 每次都要折腾一番 现在我把虚拟机连不上网的原因总体排查一下 按照流程一步步来 基本上可以解决大部分人的问题 首先 在VMware的编辑 gt 虚拟网络编辑器重新建立 网络 之前的要删掉 新建的同样选择 就可以 如
  • 线性回归总结

    向量相似理论 线性回归 比如预测房价中学区属性0 4 居住体验0 2 通勤距离0 2 商业环境0 2等因素 在同一价格区间 只有样本特征与上述属性分布一致时 各方面都加权均衡 才能取得高分 任一单一属性过高 必然导致其他属性降低 通常意义上
  • Flutter音频播放之just_audio

    just audio的使用 just audio 它是一个用于播放音频的 Flutter 插件 安装和导入 just audio 要使用 just audio 库 需要将其添加到项目的 pubspec yaml 文件中 dependenci
  • Update your application to remove the dependency cycle between beans

    Spring 高版本循环依赖问题 问题描述 提示 Spring boot 应用启动报错 Relying upon circular references is discouraged and they are prohibited by d
  • 三大战略引擎加速转动,微盟驶入智慧商业服务深水区

    2023年3月30日 微盟披露了2022年财报 经调整总收入18 39亿元 经调整毛利11 2亿元 在业务层面 订阅解决方案业务表现亮眼 其中智慧零售板块营收5 13亿元 同比内生增长45 5 拉动每用户平均收益同比增长12 3 达1296
  • (四) 区块链数据结构 – 脚本

    脚本是交易数据中的核心部分 可用于锁定输出和解锁输入 当向某人支付比特币时 我们要为交易输入设置解锁脚本 向别人证明我们有全力使用该输入 同时我们还需要对交易输出添加锁定脚本 确保只有接收者能解锁该输出 脚本 比特币系统专门设计了一套脚本语
  • games101——作业1

    文章目录 作业要求 代码框架 已有代码解读 作业部分代码 进阶部分代码 编译 结果 作业要求 在接下来的三次作业中 我们将要求你去模拟一个基于 CPU 的光栅化渲染器的简化版本 这次作业简要来说就是补全两个函数的内容 一个是 get mod
  • 数据结构实验9:并查集的使用

    问题描述 给定一个图 图中有N个顶点 1 lt N lt 500 编号依次为1 2 3 N 部分顶点之间存在一条无向边 请找出图中所有的极大连通子图 其中 极大联通子图可以描述为该子图中任意两个顶点之间都存在一条路径 且加入任何一个不在该子
  • 会议论文_干货

    研鹿论文 沿路有我 写好论文就找我 有很多同学对会议论文和期刊论文的界定并不是那么明确 那么小鹿今天就为大家详细介绍一下吧 1 会议论文是针对某个学术会议投稿的 且由学术会议的会务组决定是否录用 期刊论文则是针对某学术期刊投稿的 且是由期刊
  • python并发编程:协程asyncio、多线程threading、多进程multiprocessing

    python并发编程 协程 多线程 多进程 CPU密集型计算与IO密集型计算 多线程 多进程与协程的对比 多线程 创建多线程的方法 多线程实现的生产者 消费者爬虫 Lock解决线程安全问题 使用线程池ThreadPoolExecutor 多
  • 深度学习的局部响应归一化LRN(Local Response Normalization)理解

    1 其中LRN就是局部响应归一化 这个技术主要是深度学习训练时的一种提高准确度的技术方法 其中caffe tensorflow等里面是很常见的方法 其跟激活函数是有区别的 LRN一般是在激活 池化后进行的一中处理方法 AlexNet将LeN
  • github 配置了公钥依旧提示git@github.com‘s password: Permission denied, please try again. 的解决办法

    最近在给新电脑配置GitHub的ssh时 一切都是按照流程进行github上文档的配置流程进行配置 但是把公钥配置到github后 在对仓库进行操作的时候依旧出现一下提示 git github com s password Permissi
  • c++链表实现多项式相加

    文章目录 链表实现多项式相加 数据结构 结构体定义 链表 多项式 初始化 Insert 插入单个节点 多项式的某一项 input 输入 sum 求和函数 print 输出函数 测试代码 测试结果 链表实现多项式相加 例如 已知多项式 L 1
  • 良心分享:基于Java+SpringBoot+Netty+WebSocket+Uniapp轻松搭建准实时聊天问答程序

    一步一步教你搭建准实时聊天问答程序 微信小程序 H5网页 本文将详细介绍如何基于你自己的开源项目搭建一个准实时聊天问答程序 包括微信小程序和H5网页版 该项目服务端主要使用了Java Spring Boot Netty WebSocket等
  • 傻瓜式鸿蒙3.0使用Google(无需电脑)

    首先声明 此文仅做交流学术及为出国用户提供微不足道的帮助用 请遵守我国相关法律法规 此文仅做交流学术及为出国用户提供微不足道的帮助用 请遵守我国相关法律法规 此文仅做交流学术及为出国用户提供微不足道的帮助用 请遵守我国相关法律法规 可以先给
  • jsp+mysql分页技巧:巧用limit 进行分页查询

    发现问题 今天检查web程序 浏览 彩信xxxx日志 时 突然发现该web程序中不能浏览了 出错了 如下 500 Servlet Exception java lang OutOfMemoryError Resin 3 0 6 built