Spring Mybatis PageHelper 设置使用
PageHelper是一个Mybatis的分页插件, 负责将已经写好的sql语句, 进行分页加工.
设置
现在使用的是PageHelper 5.0 版本 :
在build.gradle先引用jar包:
// https://mvnrepository.com/artifact/com.github.pagehelper/pagehelper
compile group: 'com.github.pagehelper', name: 'pagehelper', version: '5.0.0'
然后在mybatis的config文件中增加配置项, 我的config文件是 mybatis_general_config.xml:
注意里面的顺序非常重要一定要放在正确的位置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 引用db.properties配置文件 -->
<!--<properties resource="config/mybatis/jdbc-mysql.properties"/>-->
<properties resource="config/mybatis/jdbc-mssql.properties"/>
<plugins>
<!-- PageHelper4.1.1 -->
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<property name="helperDialect" value="sqlserver"/>
<property name="offsetAsPageNum" value="false"/>
<property name="rowBoundsWithCount" value="false"/>
<property name="pageSizeZero" value="true"/>
<property name="reasonable" value="false"/>
<property name="supportMethodsArguments" value="true"/>
<property name="returnPageInfo" value="none"/>
</plugin>
</plugins>
<!--
development : 开发模式
work : 工作模式
-->
<environments default="mssql_dev">
<!--<environment id="development">-->
<!--<transactionManager type="JDBC"/>-->
<!--<!– 配置数据库连接信息 –>-->
<!--<dataSource type="POOLED">-->
<!--<property name="driver" value="${jdbc.driverClassName}"/>-->
<!--<property name="url" value="${jdbc.url}"/>-->
<!--<property name="username" value="${jdbc.user}"/>-->
<!--<property name="password" value="${jdbc.pass}"/>-->
<!--</dataSource>-->
<!--</environment>-->
<environment id="mssql_dev">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driverClassName}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<mappers>
<!--<!– 注册userMapper.xml文件,-->
<!--userMapper.xml位于me.gacl.mapping这个包下,所以resource写成me/gacl/mapping/userMapper.xml–>-->
<!--<mapper resource="resources/mapper/studentMapper.xml"/>-->
<!--<mapper class="lyb.anno_mapper.StudentMapper"/>-->
<!--<mapper class="lyb.mapper.StudentMapper"/>-->
<!--<mapper resource="resources/mapper/classesMapper.xml"/>-->
<!--<mapper resource="mybatis_mapper/StudentMapper.xml"/>-->
<!--<mapper resource="mybatis_mapper/PosInReportMapper.xml"/>-->
<mapper class="lyb.mapper.PosInReportMapper"/>
<mapper class="lyb.mapper.SalesOutReportMapper"/>
<mapper class="lyb.mapper.TransVouchMapper"/>
<mapper class="lyb.mapper.CurrentStockMapper"/>
<mapper class="lyb.mapper.Wcc_User_Customer_ConnMapper"/>
</mappers>
</configuration>
**这里有个坑 : **
<plugin interceptor="com.github.pagehelper.PageInterceptor">
这里的4.X版本的interceptor是PageHelper, 但是5.0版本后改成了PageInterceptor
如果设置的不对会报错.
有关具体设置详见:
https://pagehelper.github.io/docs/howtouse/
<!--
plugins在配置文件中的位置必须符合要求,否则会报错,顺序如下:
properties?, settings?,
typeAliases?, typeHandlers?,
objectFactory?,objectWrapperFactory?,
plugins?,
environments?, databaseIdProvider?, mappers?
-->
<plugins>
<!-- com.github.pagehelper为PageHelper类所在包名 -->
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<!-- 使用下面的方式配置参数,后面会有所有的参数介绍 -->
<property name="param1" value="value1"/>
</plugin>
</plugins>
如果顺序放置的不对, 也会出现不能初始化sqlSessionFactory的错误
代码里的使用方法 :
直接加上一个PageHelper的静态方法
PageHelper.startPage(2,10);
List<CurrentStockReport> reportList = mapper.getReport(params.getCustomer_code(),
params.getRegion_name(),
params.getInv_class_code(),
params.getInvcode(),
params.getBarcode());
仅有PageHelper.startPage(int pageNum, int pageSize) 后面的一个查询是会分页的, 我在这里使用的对应的mapper中的查询语句是:
SELECT
CurrentStock.AutoID,
Customer.cCusName,
DistrictClass.cDCName,
Customer.cCusCode,
CurrentStock.cWhCode,
CurrentStock.iQuantity as stock,
CurrentStock.cBatch,
Inventory.cInvStd,
Inventory.cInvName,
Inventory.cInvAddCode
FROM CurrentStock
INNER JOIN Customer ON SUBSTRING(CurrentStock.cWhCode, 1, 6) = Customer.cCusCode
INNER JOIN DistrictClass ON customer.cdccode = DistrictClass.cdccode
INNER JOIN Inventory ON Inventory.cInvCode = CurrentStock.cInvCode;
而由plugin产生的sql语句是 :
SELECT TOP 10
cCusName,
AutoID,
cDCName,
cWhCode,
stock,
cBatch,
cInvStd,
cInvName,
cInvAddCode
FROM (SELECT
ROW_NUMBER()
OVER (
ORDER BY RAND() ) PAGE_ROW_NUMBER,
cCusName,
AutoID,
cDCName,
cWhCode,
stock,
cBatch,
cInvStd,
cInvName,
cInvAddCode
FROM (SELECT
Customer.cCusName,
CurrentStock.AutoID,
DistrictClass.cDCName,
CurrentStock.cWhCode,
CurrentStock.iQuantity AS stock,
CurrentStock.cBatch,
Inventory.cInvStd,
Inventory.cInvName,
Inventory.cInvAddCode
FROM CurrentStock
LEFT OUTER JOIN Customer ON SUBSTRING(CurrentStock.cWhCode, 1, 6) = Customer.cCusCode
LEFT OUTER JOIN DistrictClass ON customer.cdccode = DistrictClass.cdccode
LEFT OUTER JOIN Inventory ON Inventory.cInvCode = CurrentStock.cInvCode
WHERE (Customer.cCusCode = '100001')) AS PAGE_TABLE_ALIAS) AS PAGE_TABLE_ALIAS
WHERE PAGE_ROW_NUMBER > 10
ORDER BY PAGE_ROW_NUMBER
这里可以看出, 本质上对于我们自己的sql插件做的事就是在外面套了一层select, 其中增加了一个column作为排序的依据.
关键在于这一句:
ROW_NUMBER() OVER (ORDER BY RAND())
ROW_NUMBER() 函数就是根据OVER之中的条件, 不断给出一个从1开始自增1的序列, 如果条件正确就一直生成.
这里通过RAND() 生成随机数, 来进行生成ROW_NUMBER(), 然后再在外面套一层SELECT作为选择分页的条件, 如PAGE_ROW_NUMBER > x 就是根据从某一页开始取, TOP y就是取多少个. 这些都是根据刚才的调用 **PageHelper.startPage(int pageNum, int pageSize) ** 计算得到的.
所以可以对任意的sql语句来进行构建分页, 以后可以看下这个插件源码.
Spring Mybatis PageHelper 设置使用的更多相关文章
- spring + Mybatis + pageHelper + druid 整合源码分享
springMvc + spring + Mybatis + pageHelper + druid 整合 spring 和druid整合,spring 整合druid spring 和Mybatis ...
- Spring+mybatis+PageHelper
为了更简单的实现数据库分页,我们不探讨自己手动修改sql语句分页,这里关于PageHelper自己配置是出现的问题进行记录下: 我采用的是Maven代码托管,在pom.xml进行如下配置: <! ...
- 关于Spring+mybatis+PageHelper分页插件PageHelper的使用策略
把插件jar包导入项目(具体上篇有介绍http://blog.csdn.net/qq_33624284/article/details/72821811) spring-mybatis.xml文件中配 ...
- Spring Boot+Mybatis+Pagehelper分页
Spring Boot 集成MyBatis和Pagehelper分页插件 mybatis-spring-boot-starter依赖树如下: pom配置 <project xmlns=" ...
- Spring+Mybatis+SpringMVC后台与前台分页展示实例(附工程)(转)
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文实现了一个后台由Spring+Mybatis+SpringMVC组成,分页采用Pag ...
- MyBatis+PageHelper实现分页
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7256105.html 前面讲到Spring+SpringMVC+MyBatis深入学习及搭建(十七)--Sp ...
- Spring+MyBatis整合过程
步骤: 1.引入Spring+MyBatis开发包 >spring(ioc aop dao)开发包 >mybatis开发包,dbcp,驱动包 >mybatis-spring.jar整 ...
- SpringMVC+Spring+MyBatis 整合与图片上传简单示例
一.思路: (一) Dao层: 1. SqlMapConfig.xml,空文件即可.需要文件头.2. applicationContext_dao.xml. a) 数据库连接池b) SqlSessio ...
- Spring+Mybatis+SpringMVC后台与前台分页展示实例(附工程)
林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文实现了一个后台由Spring+Mybatis+SpringMVC组成,分页采用Pag ...
随机推荐
- windows64位 redis安装 步骤
官方下载:http://redis.io/download 可以根据需要下载不同版本 windows版:https://github.com/MSOpenTech/redis/releases 在D盘 ...
- 基于Go实现的秒杀系统
这是基于Go语言的一个秒杀系统,这个系统分三层,接入层.逻辑层.管理层.项目源码:https://github.com/BlueSimle/SecKill 系统架构图 秒杀接入层 从Etcd中加载秒杀 ...
- Android 自定义ViewGroup 实战篇 -> 实现FlowLayout
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/38352503 ,本文出自[张鸿洋的博客] 1.概述 上一篇已经基本给大家介绍了如 ...
- MongoDB官方C#驱动的AsQueryable踩到坑了
collection.AsQueryable().Where()有4个重载,分别是: public static IQueryable<TSource> Where<TSource& ...
- hihoweek 137(简单完全背包)
题目链接:http://hihocoder.com/contest/hiho137/problem/1 题意:中文题诶- 思路:各层的成本计算不会有影响,所以我们只要把没一层的成本计算出来在求和就是答 ...
- 程序员收藏必看系列:深度解析MySQL优化(二)
程序员收藏必看系列:深度解析MySQL优化(一) 性能优化建议 下面会从3个不同方面给出一些优化建议.但请等等,还有一句忠告要先送给你:不要听信你看到的关于优化的“绝对真理”,包括本文所讨论的内容,而 ...
- 在VMware上克隆Linux虚拟机及其网卡配置方法
最近在搭建Hadoop集群,1个Master,3个Workers.使用VMware workstations创建Linux虚拟机,版本是CentOS7.安装完成并做了相应的网络配置后,使用VMware ...
- 剑指Offer的学习笔记(C#篇)-- 对称的二叉树
题目描述 请实现一个函数,用来判断一颗二叉树是不是对称的.注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的. 一 . 题目分析 递归法. 一.空树判断,单独搞出来. 二.非空树. 递归:一 ...
- spring框架_IOC与注解
1.什么是IOC? IoC(Inverse Of Control:反转控制) 2.IOC的作用是什么? 削减计算机程序的耦合(解除我们代码中的依赖关系). 3.关于程序的耦合 /** * 程序的耦合 ...
- Luogu P1637 三元上升子序列【权值线段树】By cellur925
题目传送门 emmm..不开结构体的线段树真香! 首先我们知道"三元上升子序列"的个数就是对于序列中的每个数,**它左边比他小的数*它右边比他大的数**.但是如何快速求出这两个数? ...