自己写的javabean分页呵呵

2024-04-25 11:58
文章标签 java 分页 bean 呵呵

本文主要是介绍自己写的javabean分页呵呵,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

package my.data;
import java.sql.*;
public class Fy {
Connection cn=null;
Statement sql=null;
ResultSet rs=null;
String path=""; //数据库路径
String username="";
String userpass="";
int recordcount=0;
int pagecount=0;
int p=1;
int pagesize=10;
public String getPath() {
return path;
}
public void setPath(String path,String username,String userpass) {
this.path = path;
this.username=username;
this.userpass=userpass;
}
public void setCn(Connection cn) {
this.cn = cn;
}
public Fy()
{
}
public void openDb()
{
try{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
cn=DriverManager.getConnection(path,username,userpass);
}
catch(Exception e)
{
System.err.print("error in openDb()");
}
}
public ResultSet getRs(String sqlstr)
{
try
{
sql=cn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
rs=sql.executeQuery(sqlstr);
}
catch(Exception e)
{
System.err.print("error in getRs()");
rs=null;
}
finally
{
return rs;
}
}
public ResultSet getFyRs(String sqlstr,int p,int pagesize)
{
int postion;
this.p=p;
this.pagesize=pagesize;
try
{
//取记录总数
sql=cn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);
rs=sql.executeQuery(sqlstr);
rs.last();
this.recordcount=rs.getRow();
if(recordcount!=0)
{
this.pagecount=(recordcount%pagesize==0)?(recordcount/pagesize):(recordcount/pagesize+1);
if(p<=1)
{
p=1;
}
if(p>=pagecount)
{
p=pagecount;
}
postion=(p-1)*pagesize+1;
rs.absolute(postion);
}
else
{
System.err.print("no record");
rs=null;
}
}
catch(Exception e)
{
System.err.print("error in getRs()");
rs=null;
}
finally
{
return rs;
}
}
public void closeDB(){
if(sql!=null)
{
try {
sql.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if(cn!=null)
{
try{
cn.close();
}
catch(SQLException e)
{
e.printStackTrace();
}
}
}
public String showfy(String http)
{
StringBuffer sb=new StringBuffer();
String t="";
if(recordcount==0)
{
t="数据库中没有记录!";
}
else
{
sb.append("共"+ recordcount +"条记录 ");
sb.append(p+"/"+pagecount);
sb.append(" 每页显示"+ pagesize +"条");
t=new String(sb);
}
return t;
}
}

 

 

调用

 

<%@ page language="java" contentType="text/html; charset=gb2312"
    pageEncoding="gb2312"%>
<%@ include file="../admin/conn.jsp" %>
<%@ page import="my.data.Fy" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>Insert title here</title>
</head>
<body>
<%
ResultSet rs=null;
int a=0;

Fy ofy=new Fy();
ofy.setPath("jdbc:odbc:yangzhi","sa","abc");
ofy.openDb();
rs=ofy.getRs("select top 10 id,title,date from wz_list  order by id desc");
%>
<table>
<tr><td width=10%>编号</td><td width=70%>主题</td><td width=20%>时间</td></tr>
<%while(rs.next())
{ %>
<tr>
<td width=10%>
<%=rs.getInt("id") %></td>
<td width=70%><%=rs.getString("title") %></td>
<td width=20%><%=rs.getDate("date").toLocaleString() %></td></tr>
<%} %>
</table>
<br>
<%
ofy.closeDB();

ResultSet rs2=null;
ofy.openDb();
rs2=ofy.getFyRs("select  id,title,date from wz_list where id>1 order by id desc",2,1);

%>

<table>
<tr><td width=10%>编号</td><td width=70%>主题</td><td width=20%>时间</td></tr>
<%
if(rs2!=null){
int i=0;
while(i<1 && ! rs2.isAfterLast())
{ %>
<tr>
<td width=10%>
<%=rs2.getInt("id") %></td>
<td width=70%><%=rs2.getString("title") %></td>
<td width=20%><%=rs2.getDate("date").toLocaleString() %></td></tr>
<%
i=i+1;
rs2.next();
}
}%>
</table>
<%=ofy.showfy("") %>

</body>
</html>

这篇关于自己写的javabean分页呵呵的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934617

相关文章

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空