在JSP页面中实现检索数据的分页显示

2016-01-29 12:14 172 1 收藏

在JSP页面中实现检索数据的分页显示,在JSP页面中实现检索数据的分页显示

【 tulaoshi.com - Java 】

 

    在页面中,当检索的数据很多时,通常需要分页显示数据,并要实现翻页。

下面将通过一些例程来说明实现JSP页面翻页技术的实现。

首先,在JSP中,通过JAVA servlet 来检索数据,而用JSP来调用结果来显示。

因而,此技术可分为两个部分(依赖关系):

1. 在服务器端的servlet 中的实现

要点:

&将查询条件保存到session中,取session中的查询条件

&设置Statement对象的MaxRows(确定一页显示多少行数据)

&顺序地通过执行SQL语句查询数据,按maxRows 来检索一个maxRows的数据,

再检索下一maxRows的数据,以此类推。

2. 在JSP中的显示实现

要点:

&显示maxRows条数据

&通过“”按钮或超链再次调用刚才的servlet查询下一maxRows的数据

流程如图所示:

 

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/java/)

下面通过一个例程来说明(一个servlet程序和一个JSP程序):

l querymedicine java (药 querymedicine )

包裹药;

导入 javax.servlet.*;

导入 javax.servlet.http.*;

导入 java.io.*;

导入 java.util.*;

导入 java.sql.*;

导入 Medicine.medicinelist;

导入 Medicine.searchData;

////////////////////////////////////////////////////

// 接---mutiquery.jsp页面,并从request中得到5条查询条件 ///

// 按条件查询药品,并将结果存进session的“medicinelist”中。 ///

// 张乾 2000年3月15日 ///

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/java/)

////////////////////////////////////////////////////

公共的班 querymedicine 扩大 HttpServlet {

私人的 DBConnectionManager connMgr;

//初始化全球的变量

公共的空的 init ( ServletConfig 设置)扔 ServletException {

super.init(config);

connMgr = DBConnectionManager.getInstance();

}

//========================处理 HTTP Get 请求============================

公共的空的 doGet ( HttpServletRequest请求 , HttpServletResponse反应)
扔 ServletException , IOException {

陈述 stmt=null;

连接反对= connMgr.getConnection("medicine");

如果(空的反对==){

response.sendRedirect("/medicine/con_error.html");

归还;

}

// ==================== 创建数据库Statement =============================

试一试{

stmt=con.createStatement();

}

抓住(例外 e )

{

connMgr.freeConnection("medicine",con);

response.sendRedirect("/medicine/stmt_error.html");

归还;

}

//-------------------------------------------------------------

long all_count=0;//存满足条件的药品总数

//===================从request中得到session======================

试一试{

HttpSession会议= request.getSession(false);

如果(空的会议==){

connMgr.freeConnection("medicine",con);

response.sendRedirect("/medicine/session_error.html");

归还;

}

//-----------------------------------------------------------

//======从“”提交来的参数取得前页最后一条数据的药品编码=======

串 ll_pos=request.getParameter("pos");
//如果pos=-1则表示要从头开始查

//----------------------------------------------------------

//=====================查询用的SQL语句串==========================

绳sqlstatment=& quot ;选择 medicines.ypbm, medsmalltypes.zlmc, medsupertypes.clmc,
medtypes.dlmc, medicines.ypm, medicines.zyyx, medicines.ypzy来自药,
medsmalltypes , medsupertypes , medtypes在哪儿 medicines.ypbm"+ll_pos+"
并且(( medsmalltypes.zlbm = medicines.zlbm )并且( medsupertypes.clbm = medicines.clbm )
并且( medtypes.dlbm = medicines.dlbm )并且(( medicines.del_flag =0)& quot ;;

//-----------------------------------------------------

绳 zlbm;

绳 dlbm;

绳 clbm;

绳 zyyx;

绳 ypm;

searchData slist=新建 searchData ();

同步(会议){

slist=(searchData)session.getAttribute("searchList");

}

if(ll_pos.equals("-1")){

//===表示不是由“”过来要从头开始查数据==========

如果( slist ! =null ){

同步(会议){

session.removeAttribute("searchList");

}

}

slist=新建 searchData ();

//=============从设置查询

来源:http://www.tulaoshi.com/n/20160129/1485200.html

延伸阅读
标签: Web开发
     我不是一个很有经验的程序员,在做项目的过程中会遇到很多的问题,在数据库中使用分页就是我做项目中遇到的一个问题.我从网上查了很多资料,有很多种方法.但我觉的创建临时数据表是最简单的方法,在我做Membership扩展时发现原来微软也是这样用的,你可一随便打开一个Membership的存储过程看看.    &nbs...
标签: 电脑入门
如果要在一个成百上千行的数据中找到上百个没有规律的数据,那可是一种比较麻烦的事。例如,笔者学校最近进行学生资料造册工作,很多老师都在苦恼,有没有办法将手中的200名学生名单在学校总的学生名单册(3000人的Excel2007工作表)中快速找出来?这个时候,使用Excel2007的粘贴函数VlookUp(),就能让这种“复杂”的检索问题变得简单。 检...
标签: Web开发
在微软的ASP编程体系中,ADO对象的建立,使得从网页访问数据库成为一件易事,特别是ADO的Recordset对象使得控制数据的输出显示更为方便、自由。而在Visual InterDev6.0(以下简称VI6.0)中,由于Script Object Model(以下简称SOM)、Design-Time Control(以下简称DTC)以及Data Environment Object Model(以下简称DEOM)等对象模型的引入,使...
标签: ASP
      我们知道:对于一个留言簿,如果我们只让上网者能看到自己的留言而看不到其他人的留言,那么这类留言簿也就只能适用于某些特殊的地方(例如“客户意见返馈表”或“投诉留言”之类的留言,因为假如你是老板的话,你也不会愿意将自己的“伤疤”随便揭开给人看)。因此我们必须令每一位上网者都能看到留言簿中的所...
标签: PHP
  $pagesize = 2; //一页显示记录数 $con = odbc_connect("access_test","","",SQL_CUR_USE_ODBC) or die("无法连接ODBC数据源access_test"); //连接一个ODBC数据源 $sql = "select count(*) as total from test"; //取得记录总数SQL语句 $rst = odbc_exec($con,$sql) or die("$...

经验教程

315

收藏

92
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部