详解Mybatis分页插件 - 示例代码

这里说最好用,绝对不是吹的,不过有好多人都不理解为什么要用这个插件,自己手写分页sql不是挺好吗......

所以我特地写这样一个例子来讲为什么最好用。

假设我们已经写好了Mapper的接口和xml,如下:

public interface SysLoginLogMapper {
  /**
   * 根据查询条件查询登录日志
   * @param logip
   * @param username
   * @param loginDate
   * @param exitDate
   * @return
   */
  List<SysLoginLog> findSysLoginLog(@Param("logip") String logip,
                   @Param("username") String username,
                   @Param("loginDate") String loginDate,
                   @Param("exitDate") String exitDate,
                   @Param("logerr") String logerr); 

} 
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.easternie.sys.dao.SysLoginLogMapper">
 <select id="findSysLoginLog" resultType="com.easternie.sys.vo.model.SysLoginLog">
  select * from sys_login_log a
  <if test="username != null and username != ''">
   left join sys_user b on a.userid = b.userid
  </if>
  <where>
   <if test="logip!=null and logip != ''">
    a.logip like '%'||#{logip}||'%'
   </if>
   <if test="username != null and username != ''">
    and (b.username like '%'||#{username}||'%' or b.realname like '%'||#{username}||'%')
   </if>
   <if test="loginDate!=null and loginDate!=''">
    and to_date(substr(a.logindate,0,10),'yyyy-MM-dd') = to_date(#{loginDate},'yyyy-MM-dd')
   </if>
   <if test="exitDate!=null and exitDate!=''">
    and to_date(substr(a.EXITDATE,0,10),'yyyy-MM-dd') = to_date(#{exitDate},'yyyy-MM-dd')
   </if>
   <if test="logerr!=null and logerr!=''">
    and a.logerr like '%'||#{logerr}||'%'
   </if>
  </where>
  order by logid desc
 </select>
</mapper>

虽然是举个简单例子,但是这里的xml并没那么简单。

如果你已经有一些例如上面这些现成的Mybatis方法了,我现在想对这个查询进行分页,我该怎么办呢?

如果是手写SQL,我需要增加两个接口,一个查询count总数,一个改为分页形式的。需要在xml中,复制粘贴,然后改改语句,似乎也不是很难。你是这样做的吗?

如果使用这个插件,我需要做什么呢???

对Mybatis已经写好的这些方法来说,我什么都不需要改。

但是Service层可能需要动一下。具体上面这个例子。看下面的Service层调用代码。

不需要分页时候的代码:

public List<SysLoginLog> findSysLoginLog(String loginIp,
                     String username,
                     String loginDate,
                     String exitDate,
                     String logerr) throws BusinessException {
  return sysLoginLogMapper.findSysLoginLog(loginIp, username, loginDate, exitDate, logerr);
}

增加分页功能之后的代码:

public PageHelper.Page<SysLoginLog> findSysLoginLog(String loginIp,
                     String username,
                     String loginDate,
                     String exitDate,
                     String logerr,
                     int pageNumber,
                     int pageSize) throws BusinessException {
  PageHelper.startPage(pageNumber,pageSize);
  sysLoginLogMapper.findSysLoginLog(loginIp, username, loginDate, exitDate, logerr);
  return PageHelper.endPage();
}

相比较而言:

返回值从List<SysLoginLog>改成了PageHelper.Page<SysLoginLog>

入参增加了两个,pageNumber和pageSize

然后过程代码中,先调用了

PageHelper.startPage(pageNumber,pageSize);

startPage是告诉拦截器说我要开始分页了。分页参数是这两个。

然后调用原来的Mybatis代码:

sysLoginLogMapper.findSysLoginLog(loginIp, username, loginDate, exitDate, logerr); 

这里没有接收返回值,会不会觉得奇怪?实际上PageHelper已经自动接收了返回值。通过下面的代码可以取出返回值:

PageHelper.endPage(); 

同时endPage告诉拦截器说我结束分页了,不需要你了。

你觉得这样的代码简单还是手写sql简单呢?

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • MyBatis存储过程、MyBatis分页、MyBatis一对多增删改查操作

    一.用到的实体类如下: Student.java package com.company.entity; import java.io.Serializable; import java.util.Date; public class Student implements Serializable{ private static final long serialVersionUID = 1L; private int id; private String name; private Date

  • Mybatis全面分页插件

    根据下面分页的思想,很容易实现Mybitas的多租户设计. 使用Mybatis提供的拦截器.对分页的SQL语句通过封装处理,处理成不同的分页sql. 本例已经实现了对Mysql和Oracle的分页功能.注意下面的引用包,不要引用错了. import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.

  • Mybatis常用分页插件实现快速分页处理技巧

    在未分享整个查询分页的执行代码之前,先了解一下执行流程. 1.总体上是利用mybatis的插件拦截器,在sql执行之前拦截,为查询语句加上limit X X 2.用一个Page对象,贯穿整个执行流程,这个Page对象需要用Java编写前端分页组件 3.用一套比较完整的三层entity,dao,service支持这个分页架构 4.这个分页用到的一些辅助类 注:分享的内容较多,这边的话我就不把需要的jar一一列举,大家使用这个分页功能的时候缺少什么就去晚上找什么jar包即可,尽可能用maven包导入

  • Java的MyBatis框架中实现多表连接查询和查询结果分页

    实现多表联合查询 还是在david.mybatis.model包下面新建一个Website类,用来持久化数据之用,重写下相应toString()方法,方便测试程序之用. package david.mybatis.model; import java.text.SimpleDateFormat; import java.util.Date; public class Website { private int id; private String name; private int visito

  • SpringMVC+MyBatis分页(最新)

    目前主流的Web MVC框架,除了Struts这个主力 外,还有Spring MVC,主要是由于Spring MVC配置比较简单,使用起来也十分明了,非常灵活,与Spring 集成较好,对RESTful API的支持也比struts要好. MyBatis是ibatis的升级版,作为hibernate的老对手,它 是一个可以自定义SQL.存储过程和高级映射的持久层框架. 与hibernate的主要区别就是mybatis是半自动化的,而hibernate是全自动的,所以当应用需求越来越复杂的时候,自

  • 自己动手写的mybatis分页插件(极其简单好用)

    刚开始项目,需要用到mybatis分页,网上看了很多插件,其实实现原理基本都大同小异,但是大部分都只给了代码,注释不全,所以参考了很多篇文章(每篇文章偷一点代码,评出来自己的,半抄袭),才自己模仿着写出了一个适合自己项目的分页插件,话不多说,直接上代码,相比大部分文章,注释算很完整了 最重要的拦截器 package com.dnkx.interceptor; import java.sql.*; import java.util.HashMap; import java.util.Propert

  • Mybatis实现增删改查及分页查询的方法

    MyBatis的前身就是iBatis.是一个数据持久层(ORM)框架. MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持 久层框架.MyBatis消除了几乎所有的JDBC 代码和参数的手工 设置以及结果集的检索.MyBatis使用简单的XML或注解用于 配置和原始映射,将接口和Java 的POJOs(Plan Old Java Objects,普通的Java 对象)映射成数据库中的记录.每个 MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个 SqlS

  • Spring3.1.1+MyBatis3.1.1的增、删、查、改以及分页和事务管理

    1. [代码]Mybatis全局配置文件 <plugins> < plugin interceptor = "com.has.core.page.PaginationInterceptor" /> </plugins> 2. [文件] PaginationInterceptor.java @Intercepts ({ @Signature (type = StatementHandler. class , method = "prepare

  • Java简单实现SpringMVC+MyBatis分页插件

    1.封装分页Page类 package com.framework.common.page.impl; import java.io.Serializable; import com.framework.common.page.IPage; /** * * * */ public abstract class BasePage implements IPage, Serializable { /** * */ private static final long serialVersionUID

  • Mybatis分页插件PageHelper的使用详解

    1.说明 如果你也在用Mybatis,建议尝试该分页插件,这个一定是最方便使用的分页插件. 该插件目前支持Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库分页. 2.使用方法 第一步:在Mybatis配置xml中配置拦截器插件: <plugins> <!-- com.github.pagehelper为PageHelper类所在包名 --> <plugin interceptor="com.github.pageh

随机推荐