动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Java教程 ]的信息

本月文章推荐
.谈谈J2SE中的序列化之一个感性的.
.JDBC到底是怎么连上数据库的?.
.Java 性能优化技巧集锦 (6).
.Sun复兴2大支柱:x86、Sparc服务.
.创建通过 WDO访问数据的 JSF 应用.
.值得思考的 J2EE 架构的6个最佳实.
.使用Java技术在Cocoon中实现商业.
.gsoap中文文档(5.gSoap2.x版与g.
.Spring总结实例之消息与事件.
.AtEndOfLine 属性.
.JVM的垃圾回收机制详解和调优.
.用RMI进行远程方法调用.
.java多线程设计模式详解之三.
.java指南之使用图形:动画.
.Scjp笔记.
.MIDP1.0-五子棋1.1读后的修改.
.JDBC接口技术.
.学编程的人不能不看的好文章(3).
.OpenReports 1.0-M2 发.
.Java桌面应用程序设计:SWT 简介.

分页JavaBean

发表日期:2008-1-5 |



  分页JavaBEAN

package hzdq.fdjc.Common;

import java.sql.*;
import java.util.*;

/**
* Title:分页
* Description:
* Copyright: Copyright (c) 2004
* Company:
* author:颜喜班
* @version 1.0
*/
public class SplitPager
{
/*
* _sql_str:传入的sql语句
* _total_records: 总记录数目
* _pageSize: 每页显示的记录数目
* _page: 所分的逻辑页数
*/
private Connection con=null;
private Statement stmt=null;
private ResultSet rs=null;
private ResultSetMetaData rsmd=null;
private String _sql_str;
private int _total_records;
private int _pages;
private int _pagesize;
public void setConnection(Connection con)
{
this.con=con;
if (this.con == null)
System.out.println("Failure to get a connection!");
else
System.out.println("SUCcess to get a connection!");
}
public void initialize(String sqlStr,int pageSize)
{
this._sql_str=sqlStr;
this._pagesize=pageSize;
try{
stmt=this.con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs=stmt.executeQuery(this._sql_str);
rsmd=rs.getMetaData();
if (rs!=null)
{
rs.last();
this._total_records = rs.getRow();
rs.first();
this._pages = (this._total_records - 1) / this._pagesize + 1;
}
}
catch(SQLException e){System.out.println(e.toString()); }
}
public Vector getPage(int ipage){
Vector vData=new Vector();
int n=ipage;
int m=0;
m=(n-1)*this._pagesize;
try{
if (rs!=null)
{
if (n!=1) {rs.absolute(m);}
for(int i=0;i<this._pagesize;i++){
String[] sData=new String[6];
for(int j=0;j<rsmd.getColumnCount();j++)
{
sData[j]=rs.getString(j+1);
}
if (sData==null)
{
break;
}
vData.addElement(sData);
rs.next();
}
}
rs.close();
stmt.close();
}
catch(SQLException e){System.out.println(e.toString()); }
return vData;
}
public int getPages()
{
return this._pages;
}
public int getTotalRecords()
{
return this._total_records;
}

}

jsp页面
<%@ page contentType="text/Html;charset=gb2312" language="java" %>
<%@ page import="java.sql.*"%>
<%@ page import="java.io.*" %>
<%@ page import="java.util.*" %>
<%@ page import="hzdq.fdjc.DbConn.*" %>
<jsp:useBean id="splitPager" scope="page" class="hzdq.fdjc.Common.SplitPager"/>
<%
//数据库连接
DBConnectionManager Conn=DBConnectionManager.getInstance();
Connection con=Conn.getConnection();
splitPager.setConnection(con);
int pageSize = 2;
String sqlStr = "select id,tilte from news";
splitPager.initialize(sqlStr,pageSize);
int page1=1;
//通过get数据获取当前页号
String strPage=null;//跳到的页数
strPage=request.getParameter("page1");
if (strPage==null)
{
page1=1;
}
else
{
try{page1=Integer.parseInt(strPage);}
catch(NumberFormatException e){}
if (page1<1) page1=1;
if (page1>splitPager.getPages()) page1=splitPager.getPages();
}
System.out.print("sqlStr:"+sqlStr+"page1:"+page1+"pageSize:"+pageSize);
Vector vData=splitPager.getPage(page1);
%>
<html>
<head>
<title></title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<link rel="stylesheet" href="../include/ydl.Css" type="text/css">
<script language="javascript">
function error()
{
pages=document.sinfo.page1.value;
if(!isNumber(pages))
{
document.sinfo.page1.value="";
return false;
}
}

function isNumber(inputStr)
{
for(var I=0;I<inputStr.length;I++)
{
var oneChar=inputStr.substring(I,I+1);
if((oneChar<´0´ oneChar>´9´))
{
alert("对不起,此处只能输入数字字符!!");
return false;
}
}
return true;
}

function isValid(form)
{
if(isNumber(form.page1.value))
{
form.page1.value="";
form.page1.focus();
return false;
}
else
{
return true;
}
}

function jumpto()
{
pages=document.sinfo.page1.value;
if(!isNumber(pages))
{
document.sinfo.page1.value="1";
pages="1";
}
if(pages == "")
pages = "1";
document.sinfo.page1.value = pages;
document.sinfo.submit();
}
</script>
</head>
<body bgcolor="#FFFFFF" text="#000000">
<br>
<table width="500" border="0" cellspacing="0" cellpadding="0" align="center" background="../images/lone_2.gif">
<tr>
<td width="15"><img src="http://www.QQread.com/images/lone_1.gif" width="15" height="30"></td>
<form name="sinfo" method="post" action="test.jsp" onSubmit="return isValid(this);">
<td align="right"> <font>共<%=splitPager.getTotalRecords()%>条 <%=page1%>/<%=splitPager.getPages()%>
<%=pageSize%>条/页
<%
if (page1!=1)
{
%>
<a href="test.jsp?page1=1">首页</a>
<a href="test.jsp?page1=<%=(page1-1)%>">上一页</a>
<%
}
if (page1!=splitPager.getPages())
{
%>
<a href="test.jsp?page1=<%=(page1+1)%>">下一页</a>
<a href="test.jsp?page1=<%=splitPager.getPages()%>">最后一页</a>
<%
}
%>
跳到</font>
<input type="text" name="page1" maxlength="4" size="4" style="font-size:9px" onChange="javascript:{error()}">
</td>
</form>
<td width="79"><input type="image" img src="http://www.qqread.com/images/lone_3.gif" width="79" height="30" onClick="jumpto()" alt="跳到" name="image"></td>
</tr>
</table>
<br>
<table width="98%" border="0" cellspacing="0" cellpadding="0" align="center">
<tr>
<td height="2" bgcolor="#48B9EA"></td>
</tr>
</table>
<table width="98%" border="0" cellspacing="2" cellpadding="2" align="center" background="../images/dian.gif">
<form action="" method="mothod" name="form">
<tr align="center" bgcolor="#ECECE3">
<td height="22" bgcolor="#ECECE3"><font size="2" color="#3366CC">组名</font></td>
<td width="60%" height="22"><font size="2" color="#3366CC">描述</font></td>
<td width="5%" height="22"><font size="2" color="#3366CC">选择</font></td>
</tr>
<% for(int i=0;i<vData.size();i++){
//显示数据
String[] sData=(String[])vData.get(i);
%>
<tr>
<td height="20" align="center" bgcolor="#F5F5F5"><%=sData[0]%></td>
<td width="60%" height="20" align="center" bgcolor="#F5F5F5">
<%if (sData[1]==null) out.print("");else out.print(sData[1]);%>
</td>
</tr>
<%
}

%>
</form>
</table>
<table border="0" width="400" align="center">
<tr align="center">
<td height="40">
<input type="button" name="Input" value="返 回" onClick="history.go(-1)" class="button">
</td>
<td height="40">
<input type="button" name="Input" value="添 加" onClick="add()" class="button">
</td>
<td height="40">
<input type="button" name="Input" value="修 改" onClick="mod()"class="button">
</td>
<td height="40">
<input type="button" name="Input" value="删 除" onClick="del()" class="button">
</td>
</tr>
</table>
</body>
<script language="javascript">
function add()
{
document.form.action="group_add.jsp";
document.form.method="post";
document.form.submit();
}
function mod()
{
var j=0;
var flag;
flag=false;
if (form.chkEmp.length==undefined)
{
if (form.chkEmp.checked)
flag=true;
}
for(i=0;i<form.chkEmp.length;i++)
{
if(form.chkEmp[i].checked)
{
flag=true;
j++;
}
}
if(j>1)
flag=false;
if(flag==false)
{
alert("请选择一条要修改的记录.");
return false;
}
document.form.action="group_mod.jsp";
document.form.method="post";
document.form.submit();
}

function del()
{
var flag;
flag=false;
if (form.chkEmp.length==undefined)
{
if (form.chkEmp.checked)
flag=true;
}
for(i=0;i<form.chkEmp.length;i++)
{
if(form.chkEmp[i].checked)
{
flag=true;
break;
}
}
if(flag==false)
{
alert("请选择您需要删除的记录");
return false;
}
if(!window.confirm("删除该组会删掉该组下所有朋友,确认删除(yes/No)"))
return false;
document.form.action="group_del.jsp";
document.form.method="post";
document.form.submit();
return true;
}
</script>
</html>
<%
Conn.freeConnection(con);
%>

改进如下:
package hzdq.fdjc.Common;

import java.sql.*;
import java.util.*;

/**
* Title:分页
* Description:
* Copyright: Copyright (c) 2004
* Company:
* author:颜喜班
* @version 1.0
*/
public class SplitPager
{
/*
* _sql_str:传入的sql语句
* _total_records: 总记录数目
* _pageSize: 每页显示的记录数目
* _page: 所分的逻辑页数
*/
private Connection con=null;
private Statement stmt=null;
private ResultSet rs=null;
private ResultSetMetaData rsmd=null;
private String _sql_str;
private int _total_records;
private int _pages;
private int _pagesize;
public void setConnection(Connection con)
{
this.con=con;
if (this.con == null)
System.out.println("Failure to get a connection!");
else
System.out.println("Success to get a connection!");
}
public void initialize(String sqlStr,int pageSize)
{
this._sql_str=sqlStr;
this._pagesize=pageSize;
try{
stmt=this.con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs=stmt.executeQuery(this._sql_str);
rsmd=rs.getMetaData();
if (rs!=null)
{
rs.last();
this._total_records = rs.getRow();
rs.first();
this._pages = (this._total_records - 1) / this._pagesize + 1;
}
}
catch(SQLException e){System.out.println(e.toString()); }
}
public Vector getPage(int ipage){
Vector vData=new Vector();
int n=ipage;
int m=0;
m=(n-1)*this._pagesize+1;
try{
if (rs!=null)
{
//if (n!=1) {rs.absolute(m);}
rs.absolute(m);
for(int i=0;i<this._pagesize;i++){
String[] sData=new String[6];
for(int j=0;j<rsmd.getColumnCount();j++)
{
sData[j]=rs.getString(j+1);
}
if (sData==null)
{
break;
}
vData.addElement(sData);
rs.next();
}
}
rs.close();
stmt.close();
}
catch(SQLException e){System.out.println(e.toString()); }
return vData;
}
public int getPages()
{
return this._pages;
}
public int getTotalRecords()
{
return this._total_records;
}

}
上一篇:改进后的英文字母打字游戏 人气:1801
下一篇:改善编码风格(超级简单实用) 人气:399
浏览全部Java的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-13 爬爬思特新闻管理系统 v2.0 Beta1
2008-10-13 Pligg v9.9.5 Beta
2008-10-13 广优邮件发送系统 v2.1
2008-10-13 缤纷互动视频交友 v3.1 RC
2008-10-13 MyShop网络商城 build 081005
2008-10-13 Chyrp 超轻量级开源博客引擎 v2.
2008-10-13 162100静态(论坛/文章)系统 v2.4
2008-10-13 金博人才招聘求职网黄金版 v4.2
2008-10-13 愚人笔记 v4.0
2008-10-11 联系人分组工具 v1.1 中文破解版
2008-10-11 FaceMelter变脸 v2.0 汉化破解版
2008-10-11 PathTracker道路跟踪仪 v1.2 破解
2008-10-11 Rooms手机聊天室 v0.6.7 破解版
2008-10-11 RemoteDesktop远程桌面 v1.0 破解
2008-10-11 ProRemote远程调音台 v1.0.1 破解
2008-10-11 PicShare照片共享 v1.0.0 破解版
2008-10-11 Photogene照片编辑器 v1.5 汉化破
2008-10-11 WriteRoom共享文档 v1.0 破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号