【JAVA秒会技术之玩转高效分页】EasyUI + PageHelper实现分页

简介:  EasyUI + PageHelper实现分页 一、EasyUI页面分页 页面逻辑:页面初始化时,通过jquery easyui的DataGrid(数据表格)的url属性异步加载,返回指定的json格式数据,在通过pagination属性,展示分页工具栏。   表现层分析: 请求URL:/XXX/list 请求参数:Integer page、Integer rows(ea

 EasyUI + PageHelper实现分页

一、EasyUI页面分页

页面逻辑:页面初始化时,通过jquery easyui的DataGrid(数据表格)url属性异步加载,返回指定的json格式数据,在通过pagination属性,展示分页工具栏。

 

表现层分析

请求URL:/XXX/list

请求参数:Integer pageInteger rowseasyui分页控件请求的参数),其中page默认为1。

返回数据:json格式的数据(easyui分页控件请求的返回值JSON数据),格式如下:

{total:“2”,rows:[

      {“id”:”1”,”name”:”张三”}

      {“id”:”2”,”name”:”李四”}

]}

==>  再将Json对应的数据格式封装成POJO类DatagridResult。

   业务逻辑分析

根据page和rows分页查询条件,使用分页插件PageHelper进行分页查询。

将商品列表和记录总数封装到PO类对象中,并且将其转化为Json格式返回。

二、PageHelper数据库分页

mybatis分页插件PageHelper目前支OracleMysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库分页。

分页原理

 

使用方法

第一步:dao层的pom文件中添加pagehelper依赖

    <dependency>
	  <groupId>com.github.pagehelper</groupId>
	  <artifactId>pagehelper</artifactId>
      <version>1.0</version>
</dependency>

第二步:在Mybatis配置SqlMapConfig.xml中配置拦截器插件

<plugins>
	  <!-- com.github.pagehelper为PageHelper类所在包名 -->
	  <plugin interceptor="com.github.pagehelper.PageHelper">
		  <!-- 设置数据库方言 -->
		  <property name="dialect" value="mysql" />
	  </plugin>
   </plugins>

第三步:将Json对应的数据格式封装成POJO类DatagridResult并实现序列化接口

public class DatagridResult implements Serializable{
	private long total;// 记录总数
	private List rows; // 记录集合
}

第五步:开发Service层,主要逻辑:Ø 第四步:开发Dao层,使用逆向工程生成代码;

    @Override
	public DatagridResult queryItemList(Integer page, Integer rows) {
		if (page == null)
			page = 1;
		if (rows == null)
			rows = 30;
		// 1.设置分页信息
		PageHelper.startPage(page, rows);
		// 2.执行查询
		TbItemExample example = new TbItemExample();
		List<TbItem> list = mapper.selectByExample(example);
		// 3.获取分页查询后的数据
		PageInfo<TbItem> pageInfo = new PageInfo<>(list);
		// 4.封装结果对象,并返回
		DatagridResult result = new DatagridResult();
		result.setTotal(pageInfo.getTotal()); //设置总记录数
		result.setRows(list);  //设置每页展示数据集合
		return result;
	}

 第六步:开发Controller层,主要逻辑:

   @RequestMapping("/list")
   @ResponseBody
    public DatagridResult list(@RequestParam(defaultValue= "1") Integer page, Integer rows) {
		return service.queryItemList(page, rows);
	}

三、超时及警告问题解决

    原因:通过分页插件得到的结果,其实是List的子类Page(该类由分页插件提供),而该类只在服务层,表现层没有该类,在反序列化的时候,抛出该警告,不影响使用

 

    发布服务时,服务默认的响应时间为1秒,debug时需要显示设置,单位是毫秒

 





 

相关文章
|
1天前
|
供应链 Java API
Java 8新特性解析及应用区块链技术在供应链管理中的应用与挑战
【4月更文挑战第30天】本文将深入探讨Java 8的新特性,包括Lambda表达式、Stream API和Optional类等。通过对这些新特性的详细解析和应用实例,帮助读者更好地理解和掌握Java 8的新技术。
|
2天前
|
Java 关系型数据库 MySQL
【JDBC编程】基于MySql的Java应用程序中访问数据库与交互数据的技术
【JDBC编程】基于MySql的Java应用程序中访问数据库与交互数据的技术
|
7天前
|
缓存 Java 编译器
第一章 Java线程池技术应用
第一章 Java线程池技术应用
11 0
|
7天前
|
负载均衡 Java 数据库连接
Java从入门到精通:4.2.2学习新技术与框架——不断扩展自己的知识面,跟上技术的发展趋势
Java从入门到精通:4.2.2学习新技术与框架——不断扩展自己的知识面,跟上技术的发展趋势
|
7天前
|
SQL Java 数据库连接
Java从入门到精通:3.1.2深入学习Java EE技术——Hibernate与MyBatis等ORM框架的掌握
Java从入门到精通:3.1.2深入学习Java EE技术——Hibernate与MyBatis等ORM框架的掌握
|
7天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
ava从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
|
7天前
|
消息中间件 存储 Java
Java从入门到精通:3.1.1掌握EJB、JPA、JMS等Java EE核心技术
Java从入门到精通:3.1.1掌握EJB、JPA、JMS等Java EE核心技术
|
7天前
|
设计模式 存储 前端开发
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
|
7天前
|
Java API
Java从入门到精通:2.1.5深入学习Java核心技术之文件操作
Java从入门到精通:2.1.5深入学习Java核心技术之文件操作
|
7天前
|
Java API
Java从入门到精通:2.1.4深入学习Java核心技术——Java的输入输出流
Java从入门到精通:2.1.4深入学习Java核心技术——Java的输入输出流