多学习。

PageHelper使用步骤——MyBatis分页工具

依赖

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

配置

单纯使用mybatis无spring:在MyBatis配置xml中配置拦截器插件

<!--
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>

Spring集成MyBatis:在 Spring 配置文件中配置拦截器插件

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  <property name="plugins">
         <array>
   	      <!-- 传入插件的对象 -->
   	      <bean class="com.github.pagehelper.PageInterceptor">
   		<property name="properties">
   			<props>
   			<prop key="helperDialect">mysql</prop>
   			<prop key="reasonable">true</prop>
   			</props>
   		</property>
   	     </bean>
   	</array>
  </property>
</bean>

分页参数介绍

正式使用

只需要在真正查询之前加入一段代码(一般都是在service中第一次真正查询):必须写在之前中间不可有任何语句

一个controller例子:

    @RequestMapping("/findAll.do")
    public ModelAndView findAll(@RequestParam(name="page", required = true, defaultValue = "1") int page, @RequestParam(name = "pageSize", required = true, defaultValue = "3") int pageSize){
        ModelAndView mv = new ModelAndView();
        List<Orders> os = service.findAll(page, pageSize);
        PageInfo pageInfo = new PageInfo(os);
        mv.addObject("pageInfo", pageInfo);
        mv.setViewName("orders-list");
        return mv;
    }

PageInfo类中封装了分页的各种属性:

posted @   czyaaa  阅读(99)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示