java 分页查询_java开发之分页查询

工具类

package com.luer.comm.utils;

import java.util.List;

public class PageBean {

//已知数据

private int pageNum; //当前页,从请求那边传过来。

private int pageSize; //每页显示的数据条数。

private int totalRecord; //总的记录条数。查询数据库得到的数据

//需要计算得来

private int totalPage; //总页数,通过totalRecord和pageSize计算可以得来

//开始索引,也就是我们在数据库中要从第几行数据开始拿,有了startIndex和pageSize,

//就知道了limit语句的两个数据,就能获得每页需要显示的数据了

private int startIndex;

//将每页要显示的数据放在list集合中

private List list;

//分页显示的页数,比如在页面上显示1,2,3,4,5页,start就为1,end就为5,这个也是算过来的

private int start;

private int end;

private String successMsg;

private String failMsg;

public PageBean(){}

public PageBean(int pageNum,int pageSize){

this.pageNum = pageNum;

this.pageSize = pageSize;

}

//通过pageNum,pageSize,totalRecord计算得来tatalPage和startIndex

//构造方法中将pageNum,pageSize,totalRecord获得

public PageBean(int pageNum,int pageSize,int totalRecord) {

this.pageNum = pageNum;

this.pageSize = pageSize;

this.totalRecord = totalRecord;

//totalPage 总页数

if(totalRecord%pageSize==0){

//说明整除,正好每页显示pageSize条数据,没有多余一页要显示少于pageSize条数据的

this.totalPage = totalRecord / pageSize;

}else{

//不整除,就要在加一页,来显示多余的数据。

this.totalPage = totalRecord / pageSize +1;

}

//开始索引

this.startIndex = (pageNum-1)*pageSize ;

//显示5页,这里自己可以设置,想显示几页就自己通过下面算法修改

this.start = 1;

this.end = 5;

//显示页数的算法

if(totalPage <=5){

//总页数都小于5,那么end就为总页数的值了。

this.end = this.totalPage;

}else{

//总页数大于5,那么就要根据当前是第几页,来判断start和end为多少了,

this.start = pageNum - 2;

this.end = pageNum + 2;

if(start < 0){

//比如当前页是第1页,或者第2页,那么就不如和这个规则,

this.start = 1;

this.end = 5;

}

if(end > this.totalPage){

//比如当前页是倒数第2页或者最后一页,也同样不符合上面这个规则

this.end = totalPage;

this.start = end - 5;

}

}

}

//get、set方法。

public int getPageNum() {

return pageNum;

}

public void setPageNum(int pageNum) {

this.pageNum = pageNum;

}

public int getPageSize() {

return pageSize;

}

public void setPageSize(int pageSize) {

this.pageSize = pageSize;

}

public int getTotalRecord() {

return totalRecord;

}

public void setTotalRecord(int totalRecord) {

this.totalRecord = totalRecord;

}

public int getTotalPage() {

return totalPage;

}

public void setTotalPage(int totalPage) {

this.totalPage = totalPage;

}

public int getStartIndex() {

return startIndex;

}

public void setStartIndex(int startIndex) {

this.startIndex = startIndex;

}

public List getList() {

return list;

}

public void setList(List list) {

this.list = list;

}

public int getStart() {

return start;

}

public void setStart(int start) {

this.start = start;

}

public int getEnd() {

return end;

}

public void setEnd(int end) {

this.end = end;

}

public void setSuccessMsg(String successMsg){

this.successMsg = successMsg;

}

public String getSuccessMsg(){

return successMsg;

}

public void setFailMsg(String failMsg){

this.failMsg = failMsg;

}

public String getFailMsg(){

return failMsg;

}

}

/*

* 分页查询

* pageNum:当前页

* pageSize:每页显示多少条数据

* */

@ResponseBody

@RequestMapping("/queryPage")

public PageBean queryPage(int pageNum, int pageSize){

PageBean pageBean = new PageBean();

if(pageNum > 0 && pageSize > 0) {

int totalRecord = goodsmessageService.countGoodsmessage();

pageBean = new PageBean(pageNum, pageSize, totalRecord);

//从该行开始拿数据

int startIndex = (pageNum - 1) * pageSize;

pageBean.setStartIndex(startIndex);

//数据集合

List goodsmessages = goodsmessageService.findListDataPage(startIndex, pageSize);

pageBean.setList(goodsmessages);

pageBean.setSuccessMsg("success");

}else{

pageBean.setFailMsg("error");

}

return pageBean;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
显示效果: [页面总数小于等于10,全部显示,当前页特殊显示] 上一页 1 2 3 4 5 6 7 8 9 10 下一页 [页面总数大于10,部分显示,当前页特殊显示] 上一页 1 2 3 … 20 下一页 [当前页面为首页时,上一页不可用] 上一页 1 2 3 4 … 20 下一页 上一页 1 2 3 4 5 … 20 下一页 上一页 1 2 3 4 5 6 … 20 下一页 上一页 1 … 3 4 5 6 7 … 20 下一页 上一页 1 … 14 15 16 17 18 ... 20 下一页 上一页 1 … 15 16 17 18 19 20 下一页 上一页 1 … 16 17 18 19 20 下一页 上一页 1 … 17 18 19 20 下一页 上一页 1 … 18 19 20 下一页[当前页面为末页时,下一页不可用] 算法提取: 0.页码显示规则: 当前页为首页时不显示上一页; 上一页 1 2 3 … 20 下一页 当前页为尾页时不显示下一页; 上一页 1 … 17 18 19 20 下一页 1.页面总数(n)<=10 { 显示全部页码:上一页 1 2 3 4 5 6 7 8 9 10 下一页 } 2.页面总数(n) > 10 { 2.1 当前页码 <= 4 { 左侧显示所有 + 当前页码 + 右侧2个页码 + ... + 尾页 上一页 1 2 3 … 20 下一页 上一页 1 2 3 4 … 20 下一页 上一页 1 2 3 4 5 … 20 下一页 上一页 1 2 3 4 5 6 … 20 下一页 } 2.2 当前页码 > 4 且<= 页面总数(n) - 3 { 首页 + ... + 左侧2个页码 + 当前页码 + 右侧2个页码 + ... + 尾页 上一页 1 … 3 4 5 6 7 … 20 下一页 上一页 1 … 14 15 16 17 18 ... 20 下一页 } 2.3 当前页码 > 页面总数(n) - 3 { 首页 + ... + 左侧2个页面 + 当前页码 + 右侧显示所有 上一页 1 … 15 16 17 18 19 20 下一页 上一页 1 … 16 17 18 19 20 下一页 上一页 1 … 17 18 19 20 下一页 上一页 1 … 18 19 20 下一页 } }
JTable 是一个非常常见的 Java Swing 控件,它可以方便地展示数据。如果数据量比较大,我们往往需要进行分页查看。下面是 JTable 分页查询的完整实现: 首先,我们需要定义一个分页类 PagingModel,用来管理分页相关的信息,如当前页码、每页显示的行数、总记录数等等。代码如下: ```java public class PagingModel { private int currentPage; // 当前页码 private int pageSize; // 每页显示的行数 private int totalRecords; // 总记录数 private int totalPages; // 总页数 public PagingModel(int pageSize, int totalRecords) { this.currentPage = 1; this.pageSize = pageSize; this.totalRecords = totalRecords; this.totalPages = (totalRecords + pageSize - 1) / pageSize; } public int getCurrentPage() { return currentPage; } public void setCurrentPage(int currentPage) { this.currentPage = currentPage; } public int getPageSize() { return pageSize; } public void setPageSize(int pageSize) { this.pageSize = pageSize; } public int getTotalRecords() { return totalRecords; } public void setTotalRecords(int totalRecords) { this.totalRecords = totalRecords; this.totalPages = (totalRecords + pageSize - 1) / pageSize; } public int getTotalPages() { return totalPages; } public void setTotalPages(int totalPages) { this.totalPages = totalPages; } public int getFirstResult() { return (currentPage - 1) * pageSize; } public int getMaxResults() { return pageSize; } public boolean isFirstPage() { return currentPage == 1; } public boolean isLastPage() { return currentPage == totalPages; } public void nextPage() { if (!isLastPage()) { currentPage++; } } public void previousPage() { if (!isFirstPage()) { currentPage--; } } } ``` 接下来,我们需要定义一个数据模型类,用来管理 JTable 的数据。代码如下: ```java public class MyTableModel extends AbstractTableModel { private List<Object[]> data; private String[] columnNames; public MyTableModel(List<Object[]> data, String[] columnNames) { this.data = data; this.columnNames = columnNames; } @Override public int getRowCount() { return data.size(); } @Override public int getColumnCount() { return columnNames.length; } @Override public String getColumnName(int columnIndex) { return columnNames[columnIndex]; } @Override public Object getValueAt(int rowIndex, int columnIndex) { return data.get(rowIndex)[columnIndex]; } public void setData(List<Object[]> data) { this.data = data; fireTableDataChanged(); } } ``` 其中,data 是一个 List,用来存储 JTable 的数据。每个元素都是一个 Object[],代表一行数据。columnNames 是一个 String[],用来存储 JTable 的列名。 接下来,我们需要定义一个分页查询的方法,用来查询数据并更新 JTable。代码如下: ```java public void queryDataByPage(int pageNum) { PagingModel pagingModel = new PagingModel(pageSize, totalRecords); pagingModel.setCurrentPage(pageNum); List<Object[]> data = // 执行查询语句,获取数据 myTableModel.setData(data); jTable.setModel(myTableModel); updatePageStatus(pagingModel); } private void updatePageStatus(PagingModel pagingModel) { currentPageLabel.setText(pagingModel.getCurrentPage() + ""); totalPagesLabel.setText(pagingModel.getTotalPages() + ""); totalRecordsLabel.setText(pagingModel.getTotalRecords() + ""); previousButton.setEnabled(!pagingModel.isFirstPage()); nextButton.setEnabled(!pagingModel.isLastPage()); } ``` 其中,pageSize 表示每页显示的行数,totalRecords 表示总记录数。我们先根据当前页码和总记录数计算出总页数,然后执行查询语句,获取数据。最后,更新 JTable 的数据模型和分页相关的信息。 最后,我们需要在界面上添加一些组件,如 JTable、分页按钮、分页信息等等。代码如下: ```java JTable jTable = new JTable(); MyTableModel myTableModel = new MyTableModel(new ArrayList<>(), new String[]{/* 列名 */}); int pageSize = 10; int totalRecords = // 执行查询语句,获取总记录数 PagingModel pagingModel = new PagingModel(pageSize, totalRecords); JButton previousButton = new JButton("上一页"); JButton nextButton = new JButton("下一页"); JLabel currentPageLabel = new JLabel(pagingModel.getCurrentPage() + ""); JLabel totalPagesLabel = new JLabel(pagingModel.getTotalPages() + ""); JLabel totalRecordsLabel = new JLabel(pagingModel.getTotalRecords() + ""); previousButton.addActionListener(e -> { pagingModel.previousPage(); queryDataByPage(pagingModel.getCurrentPage()); }); nextButton.addActionListener(e -> { pagingModel.nextPage(); queryDataByPage(pagingModel.getCurrentPage()); }); JPanel pagePanel = new JPanel(new FlowLayout(FlowLayout.CENTER)); pagePanel.add(previousButton); pagePanel.add(currentPageLabel); pagePanel.add(new JLabel("/")); pagePanel.add(totalPagesLabel); pagePanel.add(nextButton); JPanel infoPanel = new JPanel(new FlowLayout(FlowLayout.CENTER)); infoPanel.add(new JLabel("共 " + totalRecordsLabel + " 条记录")); JFrame frame = new JFrame(); frame.add(new JScrollPane(jTable), BorderLayout.CENTER); frame.add(pagePanel, BorderLayout.SOUTH); frame.add(infoPanel, BorderLayout.NORTH); frame.pack(); frame.setLocationRelativeTo(null); frame.setVisible(true); ``` 其中,上一页和下一页按钮的 ActionListener 中分别调用 queryDataByPage 方法来更新 JTable 和分页信息。界面上方显示分页信息,下方显示 JTable 和分页按钮。 以上就是 JTable 分页查询的完整实现。需要注意的是,这里只是一个简单的示例,实际应用中可能需要处理更多的异常情况和分页相关的细节。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值