1、定义分页模型:PageModel

  1. package com.common.page;
  2. import java.util.List;
  3. /**
  4. * 封装分页信息
  5. * @author Administrator
  6. *
  7. */
  8. public class PageModel<E> {
  9. //结果集
  10. private List<E> list;
  11. //查询记录数
  12. private int totalRecords;
  13. //每页多少条数据
  14. private int pageSize;
  15. //第几页
  16. private int pageNo;
  17. /**
  18. * 总页数
  19. * @return
  20. */
  21. public int getTotalPages() {
  22. return (totalRecords + pageSize - 1) / pageSize;
  23. }
  24. /**
  25. * 取得首页
  26. * @return
  27. */
  28. public int getTopPageNo() {
  29. return 1;
  30. }
  31. /**
  32. * 上一页
  33. * @return
  34. */
  35. public int getPreviousPageNo() {
  36. if (pageNo <= 1) {
  37. return 1;
  38. }
  39. return pageNo - 1;
  40. }
  41. /**
  42. * 下一页
  43. * @return
  44. */
  45. public int getNextPageNo() {
  46. if (pageNo >= getBottomPageNo()) {
  47. return getBottomPageNo();
  48. }
  49. return pageNo + 1;
  50. }
  51. /**
  52. * 取得尾页
  53. * @return
  54. */
  55. public int getBottomPageNo() {
  56. return getTotalPages();
  57. }
  58. public List<E> getList() {
  59. return list;
  60. }
  61. public void setList(List<E> list) {
  62. this.list = list;
  63. }
  64. public int getTotalRecords() {
  65. return totalRecords;
  66. }
  67. public void setTotalRecords(int totalRecords) {
  68. this.totalRecords = totalRecords;
  69. }
  70. public int getPageSize() {
  71. return pageSize;
  72. }
  73. public void setPageSize(int pageSize) {
  74. this.pageSize = pageSize;
  75. }
  76. public int getPageNo() {
  77. return pageNo;
  78. }
  79. public void setPageNo(int pageNo) {
  80. this.pageNo = pageNo;
  81. }
  82. }

2、分页测试:在MySQL中建立admin表,里面有字段id、name、password

3、简历Admin的实体bean类:

  1. package com.common.page;
  2. public class Admin {
  3. private int id;
  4. private String name;
  5. private String password;
  6. public int getId() {
  7. return id;
  8. }
  9. public void setId(int id) {
  10. this.id = id;
  11. }
  12. public String getName() {
  13. return name;
  14. }
  15. public void setName(String name) {
  16. this.name = name;
  17. }
  18. public String getPassword() {
  19. return password;
  20. }
  21. public void setPassword(String password) {
  22. this.password = password;
  23. }
  24. }

4、测试调用:

    1. package com.common.page;
    2. import java.sql.Connection;
    3. import java.sql.PreparedStatement;
    4. import java.sql.ResultSet;
    5. import java.sql.SQLException;
    6. import java.util.ArrayList;
    7. import java.util.List;
    8. import com.common.db.DbUtil;
    9. public class Client {
    10. public static PageModel findAdmins(int pageNo,int pageSize){
    11. Connection conn=DbUtil.getConnection();
    12. String sql="select * from admin limit ?,?";
    13. PageModel pageModel=null;
    14. PreparedStatement pstm=null;
    15. ResultSet rs=null;
    16. Admin admin=null;
    17. List<Admin> list=new ArrayList<Admin>();
    18. try {
    19. pstm=conn.prepareStatement(sql);
    20. pstm.setInt(1, (pageNo-1)*pageSize);
    21. pstm.setInt(2, pageNo*pageSize);
    22. rs=pstm.executeQuery();;
    23. while(rs.next()){
    24. admin=new Admin();
    25. admin.setId(rs.getInt("a_id"));
    26. admin.setName(rs.getString("a_name"));
    27. admin.setPassword(rs.getString("a_pwd"));
    28. list.add(admin);
    29. }
    30. ResultSet rs2=pstm.executeQuery("select count(*) from admin");
    31. int total=0;
    32. if(rs2.next()){
    33. total=rs2.getInt(1);
    34. }
    35. pageModel=new PageModel();
    36. pageModel.setPageNo(pageNo);
    37. pageModel.setPageSize(pageSize);
    38. pageModel.setTotalRecords(total);
    39. pageModel.setList(list);
    40. } catch (SQLException e) {
    41. e.printStackTrace();
    42. }finally{
    43. DbUtil.close(conn);
    44. DbUtil.close(pstm);
    45. DbUtil.close(rs);
    46. }
    47. return pageModel;
    48. }
    49. public static void main(String[] args) {
    50. PageModel pageModel=Client.findAdmins(2,4);
    51. List<Admin> list=pageModel.getList();
    52. for(Admin a:list){
    53. System.out.print("ID:"+a.getId()+",用户名:"+a.getName()+",密码:"+a.getPassword());
    54. System.out.println();
    55. }
    56. System.out.print("当前页:"+pageModel.getPageNo()+" ");
    57. System.out.print("共"+pageModel.getTotalPages()+"页  ");
    58. System.out.print("首页:"+pageModel.getTopPageNo()+" ");
    59. System.out.print("上一页:"+pageModel.getPreviousPageNo()+" ");
    60. System.out.print("下一页:"+pageModel.getNextPageNo()+" ");
    61. System.out.print("尾页:"+pageModel.getBottomPageNo()+" ");
    62. System.out.print("共"+pageModel.getTotalRecords()+"条记录");
    63. System.out.println();
    64. }
    65. }

Java 分页通用的更多相关文章

  1. java分页通用篇

    一.创建分页通用类 package com.dkyw.util; import java.util.List; public class Page<T> { private int tot ...

  2. JAVA 分页工具类及其使用

    Pager.java package pers.kangxu.datautils.common; import java.io.Serializable; import java.util.List; ...

  3. java - 分页类

    pager.java package com.jspnews.util; import java.io.Serializable; import java.util.List; /** * * < ...

  4. 数据你把它的金额-JAVA分页

    数据量你造吗-JAVA分页 原创地址:   http://www.cnblogs.com/Alandre/  (泥沙砖瓦浆木匠),须要转载的,保留下! Thanks 学习的心态第一,解行要对应. 事实 ...

  5. 浅谈Java分页技术

    话不多言.我们要实现java分页技术,我们首先就需要定义四个变量,他们是: int  pageSize;//每页显示多少条记录 int pageNow;//希望现实第几页 int pageCount; ...

  6. 一个方便的java分页算法

    一个好用的java分页算法,代码如下,只需要分页参数继承Pageable类就可以很方便分页了 package cn.com.base.common.pagination; /** * 分页基类 * * ...

  7. [Java] 一种好的JAVA分页实现

    喃都不说了,贴代码,意思都在代码里面了 Page.java //分页类.定义分页字段信息,供前台页面使用 package com.core.common; import java.util.List; ...

  8. Java中都通用文件下载(ContentType、文件头、response、out四步骤)

    Java中都通用文件下载(ContentType.文件头.response.out四步骤) 新浪微博:IT国子监(记得关注噢) http://weibo.com/itguozijian   我们就直接 ...

  9. pagebean pagetag java 后台代码实现分页 demo 前台标签分页 后台java分页

    java 后台代码实现分页 demo 实力 自己写的 标签分页 package com.cszoc.sockstore.util; import java.util.HashMap;import ja ...

随机推荐

  1. 01从c到c++

    c++的发展历史  + 80年代贝尔实验室 本贾尼 + 83年 正式命名c++ + 87年 gnu制定了c++标准 + 92年 微软和IBM分别制定了c++标准 + 98年 ansi ISO 制定了标 ...

  2. 【巩固】JS中的封闭空间

    封闭空间的主要思想在于: JS中给一个变量外面加小括号,是不改变任何结果的.比如 var show = function(){ //定义一个名字为show的函数 ); }; show(); //调用名 ...

  3. OAF_开发系列26_实现OAF中Java类型并发程式开发oracle.apps.fnd.cp.request(案例)

    20150730 Created By BaoXinjian

  4. 移动web开发,12个触摸及多点触摸事件常用Js插件

    如今移动互联网已经占据了主流地位,越来越多的开发者开始从桌面转向移动平台.与桌面开发不同的是,在移动领域中,不同的操作系统.大量不同屏幕尺寸的移动设备.触摸手势操作等,这都给开发者带来了一定的难度和挑 ...

  5. sysbench压力测试工具简介和使用(二)

    sysbench压力测试工具使用: 2.1    测试数据库服务器的硬件配置信息如下: CPU:      24核心线程数,Intel(R) Xeon(R) CPU E5-2620 0 @ 2.00G ...

  6. java 无符号byte转换

    java中的byte类型是有符号的,值得范围是-128-127 做网络通讯时,接收过来的数据往往都是无符号的byte,值得范围是0-255 因此直接转换时,存储到java显示的值就会有问题 int o ...

  7. windows 下编译log4cxx(x64)

    参考链接 http://blog.csdn.net/hnu_zxc/article/details/7786060 http://blog.chinaunix.net/uid-20384806-id- ...

  8. android的四层体系结构,基于mvc三层结构浅析

    从多方面理解Android体系结构 1.以分层的方式来看Android 安卓体系结构分为四层. 首先看一下官方关于Android体系结构的图: 1).Linux Kernel:负责硬件的驱动程序.网络 ...

  9. 转载-------makefile 使用总结

    转载自:http://www.cnblogs.com/wang_yb/p/3990952.html 1. Makefile 简介 Makefile 是和 make 命令一起配合使用的. 很多大型项目的 ...

  10. Nopcommerce 二次开发1 基础

    1  Doamin    酒店 namespace Nop.Core.Domain.Hotels { /// <summary> /// 酒店 /// </summary> p ...