Mybatis分页插件PageHelper正确的用法(网上有2篇不够科学的文章)「建议收藏」

Mybatis分页插件PageHelper正确的用法(网上有2篇不够科学的文章)

大家好,又见面了,我是全栈君。

今天下午在Mybatis项目中。实现分页。由于我是后加入项目中的,Leader用的是PageHelper这个组件。可是我在实际使用的过程中遇到了2个大问题。

 1.
    在这篇文章中。作者有提到须要添加PageHelper的配置,原话“或者假设你使用Maven,你能够加入例如以下依赖: 

   这句话是有问题的,
  
<plugins>

    
<!-- com.github.pagehelper为PageHelper类所在包名 -->
    
<
plugin 
interceptor
=
"com.github.pagehelper.PageHelper"
>
        
<
property 
name
=
"dialect" 
value
=
"mysql"
/>
        
<!-- 该參数默觉得false -->
        
<!-- 设置为true时,会将RowBounds第一个參数offset当成pageNum页码使用 -->
        
<!-- 和startPage中的pageNum效果一样-->
        
<
property 
name
=
"offsetAsPageNum" 
value
=
"true"
/>
        
<!-- 该參数默觉得false -->
        
<!-- 设置为true时,使用RowBounds分页会进行count查询 -->
        
<
property 
name
=
"rowBoundsWithCount" 
value
=
"true"
/>
    
</
plugin
>
</
plugins
>
   这几段插件配置的代码。应该放到Mybatis的config配置文件里,而非Maven。
  
   后来。听Leader说,他在这也被误导了。搞了一天时间吧。

2. 

http://www.oschina.net/p/mybatis_pagehelper
   作者使用PageHelper的方法不太对,尽管Java后台測试是能够的。可是在FTL中显示的时候,EL表达式不能正常显示。

   作者的代码:
   
@Test

public
void
testPageHelperByStartPage() 
throws
Exception {
    
String logip = 
""
;
    
String username = 
"super"
;
    
String loginDate = 
""
;
    
String exitDate = 
null
;
    
String logerr = 
null
;
    
//不进行count查询。第三个參数设为false
    
PageHelper.startPage(
1

10

false
);
    
//返回结果是Page<SysLoginLog>    
    
//该对象除了包括返回结果外。还包括了分页信息,能够直接按List使用
    
List<SysLoginLog> logs = sysLoginLogMapper
            
.findSysLoginLog(logip, username, loginDate, exitDate, logerr);
    
Assert.assertEquals(
10
, logs.size());
 
    
//当第三个參数没有或者为true的时候,进行count查询
    
PageHelper.startPage(
2

10
);
    
//返回结果是Page<SysLoginLog>    
    
//该对象除了包括返回结果外,还包括了分页信息,能够直接按List使用
    
Page<SysLoginLog> page = (Page<SysLoginLog>) sysLoginLogMapper
            
.findSysLoginLog(logip, username, loginDate, exitDate, logerr);
    
Assert.assertEquals(
10
, page.getResult().size());
    
//进行count查询。返回结果total>0
    
Assert.assertTrue(page.getTotal() > 
0
);
}

    假设在Freemarker的FTL页面中。打印${

page.pageNum
}会报错,大致的意思是“expected a hash,but is a sequence”。
期待是hash类型,但实际上序列,list、ArrayList都算作序列。

    这个地方情况比較特殊,
Page是一个JavaBean。有若干属性,可是他又继承了ArrayList。经实际分析,
Freemarker把这个对象当作了ArrayList,能够直接遍历<#list page as item></#list>。

     正确的方法应该是:

   
PageHelper.startPage(
1

10
);

List<Country> list = countryMapper.selectAll();
PageInfo page = 
new 
PageInfo(list);
assertEquals(
10
, list.size());

 
  今天遇到了这2个大问题。特意总结下,希望后来的人,不要再被误导了。

  除了PageHelper这个分页插件,我在秒针工作的时候,原秒针Web前端高级project师 现百度高级project师,
张少龙-默默。
他也自己实现了一个插件,今后再分享出来。

小雷FansUnion
2014年10月20日
湖北武汉

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115764.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 数组和链表的区别?「建议收藏」

    数组和链表的区别?「建议收藏」今天来说下两种最基本的数据结构——数组和链表,它们无处不在!下面我们来一一介绍下他们,首先了解下内存分配的!内存的工作原理假设你去看演出,需要将东西寄存。寄存处有一个柜子,柜子有很多抽屉。每个抽屉可放一样东西,你有两样东西要寄存,因此要了两个抽屉。现在你可以去看演出了!这大致就是计算机内存的工作原理。计算机就像是很多抽屉的集合体,每个抽屉都有地址。fe0ffeeb是一个内存单元的地址。需要将数据存储到内存时,你请求计算机提供存储空间,计算机给你一个存储地址。需要存储多项数据时,有两种基本方式

    2022年6月28日
    23
  • Git使用流程_git提交流程

    Git使用流程_git提交流程以coding为例,演示如何使用git首先理解下整个流程,如图一,将本地代码上传到远程仓库1.(电脑里得先下载git)登录coding,新建一个仓库,点击代码浏览可以看到2.在本地新建一个文件夹,作为项目根目录,再此启动GitBash,进入目录,并输入gitinit初始化一个本地git仓库3.将本地仓库和我们在coding上创建的远程仓库对接起来,输入gitre…

    2022年9月23日
    3
  • 用plsql将excel导入oracle,使用工具 plsqldev将Excel导入Oracle数据库

    用plsql将excel导入oracle,使用工具 plsqldev将Excel导入Oracle数据库使用工具 plsqldev 将 Excel 导入 Oracle 数据库 1 使用工具 plsqldev2 打开需导入的 excel 表格 单击 office 按钮 选择另存为其他格式 选择保存类型 CSV 逗号分隔 csv 单击保存 3 打开 plsqldev 在工具栏中选择 Tools 下拉菜单下的 TextImporter 进入后选择 datafromtext 标签 单击下面带有红线框的按钮打开 cs

    2025年8月1日
    8
  • 散列函数

    散列函数    在线性表和树表中的查询中,记录在表的位置跟记录的关键字之间不存在确定关系,也就是说在线性表和树表中查询通常要依托关键字比较,查找的效率取决于比较次数。    散列函数:一个把查找表中的关键字映射成该关键字对应的地址函数,记为Hash(key)=Addr。这里的地址可以是数组下标,索引,或内存地址等。散列函数可能将两个或两个以上的不同关键字映射到同一个地址,称这种情况为“冲突”。(假若这个函…

    2022年5月14日
    66
  • CANoe/CANalyzer诊断功能的深入理解以及CAPL诊断编程实现

    CANoe/CANalyzer诊断功能的深入理解以及CAPL诊断编程实现之前和大家分享了CANoe的基础使用(分析、仿真、测试、诊断),这篇文章将继续深入探讨如何使用CANoe/CANalyzer中的诊断功能。诊断用于在将ECU安装到系统之前或之后配置,维护,支持,控制和扩展ECU,例如,一辆车。诊断通常在请求-响应方案中执行:测试仪(客户端)向…

    2022年6月30日
    95
  • python深拷贝和浅拷贝详解_Java浅拷贝和深拷贝的区别

    python深拷贝和浅拷贝详解_Java浅拷贝和深拷贝的区别Python深拷贝和浅拷贝详解浅拷贝,指的是重新分配一块内存,创建一个新的对象,但里面的元素是原对象中各个子对象的引用。深拷贝,是指重新分配一块内存,创建一个新的对象,并且将原对象中的元素,以递归的方式,通过创建新的子对象拷贝到新对象中。因此,新对象和原对象没有任何关联。1.浅拷贝使用数据类型本身的构造器对于可变的序列,还可以通过切片操作符:来完成浅拷贝Python还提供了对应的函数copy.copy()函数,适用于任何数据类型1.1使用数据类型本身的构造器lis

    2025年8月13日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号