java如何分页_如何用java实现分页查询

1.基本思路

我现阶段的分页查询的实现是基于sql语句的。

select * from user where id limit a, b

构造出相应的a和b就可以查询出想要的数据,在显示在页面上。重点是要构造出当前的页数,就要封装一个javaBean,存储有关分页的基本属性。

这样只需在service层计算想要的页数,并封装基本的信息,在查询出来显示在前端就可以了。

2.具体实现

1.定义JavaBean

public @Data

class PageBean implements Serializable {

private Integer page;//当前页数

private Integer limit;//每页显示数

private Integer totalPage;//总页数

private Integer total;//总记录数

private List pageRecode;//当前页面的数据集合

private List pages;//返回页数的集合,用于显示index页面的上一页、下一页

}

2.controller:

PageBean pageBean = questionService.questionList(page);

返回一个QuestionDTO类型的JavaBean,其中包含了分页的一些信息和当前页面所要显示的数据集合。有关QuestionDTO:

public @Data

class QuestionDTO {

private Integer id;

private String title;

private String description;

private Long gmtCreate;

private Long GmtModified;

private Integer creator;

private Integer attentionCount;

private Integer viewCount;

private Integer likeCount;

private String tag;

private User user;

}

3.调用的Service:

//查询所有的问题回显到index页面

public PageBean questionList(Integer page) {

List list = new ArrayList<>();

PageBean pagesinfo = new PageBean<>();

//1.设置limit

Integer limit = 5;

pagesinfo.setLimit(limit);

//2.设置总记录数

Integer total = questionMapper.fingCount();

pagesinfo.setTotal(total);

//3.设置总的页数

Integer totalPage;

if(total % limit == 0){

totalPage = total / limit;

}else{

totalPage = total / limit + 1;

}

pagesinfo.setTotalPage(totalPage);

//4.设置页数的集合

List pages = new ArrayList<>();

for(int i=1;i

pages.add(i);

}

pagesinfo.setPages(pages);

//5.设置每页的数据集合

List questions = questionMapper.questionList(page,limit);

for(Question question : questions){

User user = userMapper.findById(question.getCreatar());

QuestionDTO questionDTO = new QuestionDTO();

BeanUtils.copyProperties(question,questionDTO);

questionDTO.setUser(user);

list.add(questionDTO);

}

pagesinfo.setPageRecode(list);

return pagesinfo;

}

在service层为PageBean的属性赋值,并且查询出相关的数据。上述代码中第5步如果有疑惑请参照多表联合查询的简单另类的实现方式。

4.mapper

//查询所有的问题并回显到index页面

@Select("select * from question where id limit #{page},#{limit}")

List questionList(Integer page, Integer limit);

//查询总的问题数

@Select("select count(id) from question")

Integer fingCount();

做完这些,controller中的PageBean中就会封装有查询的数据。在返回前端显示就完成了。

5.前端代码

«

»

循环取出page。

另一种方式,使用mybatis-generator生成的分页查询方法

1.新建generatorConfig.xml配置文件‘

/p>

PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"

"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">

connectionURL="jdbc:mysql://localhost:3306/community?characterEncoding=utf-8&serverTimezone=UTC"

userId="root"

password="root">

注:

1.配置文件的名称固定是generatorConfig.xml

2.在控制台运行命令mvn -Dmybatis.generator.overwrite=true mybatis-generator:generate生成带有分页查询方法的代码

注:overwrite=true会覆盖掉前一次生成的代码,可根据实际需求进行调整。

3.举例:

QuestionExample example = new QuestionExample();

example.createCriteria().

andCreatorEqualTo(id);

List questions = questionMapper.selectByExampleWithRowbounds(example, new RowBounds(page,limit));

设置好页数和每一页显示的个数,就可以返回对应的结果集。也同样可以做到分页。

持续更新~~~

以上就是如何用java实现分页查询的详细内容,更多关于java实现分页查询的资料请关注脚本之家其它相关文章!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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、付费专栏及课程。

余额充值