PageHelper分页插件

 

商品分页查询 ego-prc 实现
 
1.1 功能分析
使用 easyui 的 DataGrid 控件实现商品的分页查询,DataGrid 控件提交分页所需要的 page 和
rows 参数(  page:第几页,  rows:每页显示的记录数),

后台响应包含总记录数 total需要显示的商品对象的集合 rows 的 json 对象。

 
1.2PageHelper 说明
 
1.2.1PageHelper 资源地址
 
https://github.com/pagehelper/Mybatis-PageHelper
 
1.2.2PageHelper 实现原理

 

 

 
 

 在查询的sql语句执行之前,添加一行代码PageHelper.startPage(1, 10);第一个参数表示第几页,第二个参数表示每页显示的记录数。这样在执行sql后就会将记录按照语句中设置的那样进行分页。如果需要获取总记录数的话,需要PageInfo类的对象,这个对象可以获取总记录数,下面看下测试的代码。

 

1.2.3PageHelper 配置

(在mybatis配置文件中配置)
<!-- 配置分页插件 --> <plugins> <plugin interceptor="com.github.pagehelper.PageHelper">
<!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六
种数据库 --><property name="dialect" value="mysql" />
</plugin>
</plugins>

1.3ego-common

 
 
创建 PageResult 类
 
复制代码
package com.bjsxt.ego.beans;
import java.io.Serializable;
import java.util.List;
/**
* 封装datagrid控件需要的数据模型
* **/
public class PageResult<T> implements Serializable{
private List<T> rows;
private Long total;
public List<T> getRows() {
return rows; }
public void setRows(List<T> rows) {
this.rows = rows; }
public Long getTotal() {
return total; }
public void setTotal(Long total) {
this.total = total; } }
View Code
复制代码
1.4 创建 ItemService 接口
复制代码
package com.bjsxt.ego.rpc.service;
import com.bjsxt.ego.beans.PageResult;
import com.bjsxt.ego.rpc.pojo.TbItem;
public interface ItemService {
/**
* 实现商品信息的分页查询
* **/
public PageResult<TbItem> selectItemList(Integer page,Integer rows);
}
View Code
复制代码
1.5 创建 ItemServiceImpl 实现类
 
复制代码
package com.bjsxt.ego.rpc.service.impl;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.bjsxt.ego.beans.PageResult;
import com.bjsxt.ego.rpc.mapper.TbItemMapper;
import com.bjsxt.ego.rpc.pojo.TbItem;
import com.bjsxt.ego.rpc.pojo.TbItemExample;
import com.bjsxt.ego.rpc.service.ItemService;
import com.github.pagehelper.Page;
import com.github.pagehelper.PageHelper;
@Service
public class ItemServiceImpl implements ItemService {
//注入mapper接口代理对象
@Autowired
private TbItemMapper tbItemMapper;
@Override
public PageResult<TbItem> selectItemList(Integer page, Integer rows) {
// TODO Auto-generated method stub
//执行分页操作
Page ps = PageHelper.startPage(page, rows);
TbItemExample example=new TbItemExample();
//执行数据库查询操作
List<TbItem> list = tbItemMapper.selectByExample(example);
PageResult<TbItem> result = new PageResult<TbItem>();
result.setRows(list);
result.setTotal(ps.getTotal());
return result; } }
复制代码

1.6 配置 applicationContext-dubbo.xml

<!-- 发布dubbo服务 --> <dubbo:service interface="com.bjsxt.ego.rpc.service.ItemService"
ref="itemServiceImpl"></dubbo:service>

 

1.7 启动 ego-rpc-service-impl 发布 RPC 服务

复制代码
package com.bjsxt.ego.test;
import java.io.IOException;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class ProviderTest {
public static void main(String[] args) {
/**
* 加载spring容器,完成服务发布
* **/
ClassPathXmlApplicationContext ac= 
new
ClassPathXmlApplicationContext("spring/applicationContext-dao.xml",
"spring/applicationContext-service.xml",
"spring/applicationContext-tx.xml",
"spring/applicationContext-dubbo.xml");
ac.start();
//阻塞程序的运行
try {
System.in.read();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
ac.stop();
} }
View Code
复制代码

 

商品分页查询 ego-manager-web 实现
 
2.1 配置 applicationContext-dubbo.xml
<!-- spring容器中存在一个远程服务的代理对象 --> <dubbo:reference interface="com.bjsxt.ego.rpc.service.ItemService"
id="itemServiceProxy"></dubbo:reference>
2.2 创建 ManagerItemService 接口
复制代码
package com.bjsxt.ego.manager.service;
import com.bjsxt.ego.beans.PageResult;
import com.bjsxt.ego.rpc.pojo.TbItem;
public interface ManagerItemService {
/**
* 完成商品信息的分页查询
* **/
public PageResult<TbItem> selectItemListService(Integer page ,Integer rows);
}
View Code
复制代码
2.3 创建 ManagerItemServiceImpl 实现类
复制代码
package com.bjsxt.ego.manager.service.impl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.bjsxt.ego.beans.PageResult;
import com.bjsxt.ego.manager.service.ManagerItemService;
import com.bjsxt.ego.rpc.pojo.TbItem;
import com.bjsxt.ego.rpc.service.ItemService;
@Service
public class ManagerItemServiceImpl implements ManagerItemService {
//注入的是远程服务的代理对象
@Autowired
private ItemService itemServiceProxy;
@Override
public PageResult<TbItem> selectItemListService(Integer page, Integer rows) {
// TODO Auto-generated method stub
return itemServiceProxy.selectItemList(page, rows);
} }
View Code
复制代码

 

 

2.4 创建 ItemController 类

复制代码
package com.bjsxt.ego.manager.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import com.bjsxt.ego.beans.PageResult;
import com.bjsxt.ego.manager.service.ManagerItemService;
import com.bjsxt.ego.rpc.pojo.TbItem;
@Controller
public class ItemController {
//注入service对象
@Autowired
private ManagerItemService managerItemService;
/***
* 处理商品信息分页查询的请求
* **/
@RequestMapping(value="item/list",produces=MediaType.APPLICATION_JSON_VALU
E+";charset=UTF-8")
@ResponseBody
public PageResult<TbItem> itemList(@RequestParam(defaultValue="1")Integer 
page,
@RequestParam(defaultValue="30")Integer rows){
return managerItemService.selectItemListService(page, rows);
} }
View Code
复制代码

 

2.5 发布 ego-manager-web 访问商品列表

 JsonResult类

复制代码
package com.hainei.common.utils;

/**
 * FileName: JsonResult
 * Author:   Administrator
 * Date:     2019/6/24 20:20
 * Description: 返回数据api
 */
public class JsonResult {

    // 响应业务状态
    private Integer status;

    // 响应消息
    private String msg;

    // 响应中的数据
    private Object data;

    public static JsonResult build(Integer status, String msg, Object data) {
        return new JsonResult(status, msg, data);
    }

    public static JsonResult ok(Object data) {
        return new JsonResult(data);
    }

    public static JsonResult ok() {
        return new JsonResult(null);
    }

    public JsonResult() {

    }

    public static JsonResult build(Integer status, String msg) {
        return new JsonResult(status, msg, null);
    }

    public JsonResult(Integer status, String msg, Object data) {
        this.status = status;
        this.msg = msg;
        this.data = data;
    }

    public JsonResult(Object data) {
        this.status = 200;
        this.msg = "OK";
        this.data = data;
    }

    public Integer getStatus() {
        return status;
    }

    public void setStatus(Integer status) {
        this.status = status;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public Object getData() {
        return data;
    }

    public void setData(Object data) {
        this.data = data;
    }
}
View Code
复制代码

 

 PageHelper.startPage(query.getPageNum(), query.getPageSize());
        List<EmergencyFireCar> emergencyFireCars = emergencyFireCarService.listAll(query);
        PageInfo<EmergencyFireCar> pageInfo = new PageInfo<>(emergencyFireCars);

 

 

关于pagehelper的详细使用博客

https://blog.csdn.net/eson_15/article/details/52270046

posted @   wq9  阅读(351)  评论(1编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
阅读排行:
· 《HelloGitHub》第 106 期
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用
点击右上角即可分享
微信分享提示