PageHelper使用方法

第一步:先在pom.xml中添加如下
<properties>
  <pagehelper-version>5.0.0</pagehelper-version>
  <jsqlparser-version>0.9.5</jsqlparser-version>
</properties>
<!--pagehelper-->
<dependency>
  <groupId>com.github.pagehelper</groupId>
  <artifactId>pagehelper</artifactId>
  <version>${pagehelper-version}</version>
</dependency>

<!-- pagehelper的依赖包:jsqlparser -->
<dependency>
  <groupId>com.github.jsqlparser</groupId>
  <artifactId>jsqlparser</artifactId>
  <version>${jsqlparser-version}</version>
</dependency>

第二步:在spring-mybatis整合xml中添加如下

(主要是在sqlSessionFactory里面注入一个plugins,然后配置pageHelper的信息即可)

<!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <property name="dataSource" ref="dataSource"/>
    <!-- 自动扫描mapping.xml文件 -->
    <property name="mapperLocations" value="classpath*:mapping/**/*.xml"></property>
    <!--pageHelper-->
    <property name="plugins">
        <array>
            <bean class="com.github.pagehelper.PageInterceptor">
                <property name="properties">
                    <!--使用下面的方式配置参数,一行配置一个 -->
                    <value>
                        helperDialect=postgresql
                        reasonable=true
                        supportMethodsArguments=true
                        params=count=countSql
                        autoRuntimeDialect=true
                    </value>
                </property>
            </bean>
        </array>
    </property>
</bean>

第三步:在controller中

@RequestMapping("pageHelperTest")
public void getList(){
   userService.test();  //调用service层的方法
}

第四步:在service中使用pageHelper

public void test(){
   PageHelper.startPage(1, 5);   //第一个参数代表当前页码  第二个参数代表每页多少条记录数
   ArrayList<Users> list = userDao.getUserList();
   PageInfo<Users> page = new PageInfo<Users>(list);
   System.out.println("总数量:" + page.getTotal());
   System.out.println("当前页查询记录:" + page.getList().size());
   System.out.println("当前页码:" + page.getPageNum());
   System.out.println("每页显示数量:" + page.getPageSize());
   System.out.println("总页:" + page.getPages());
}

第五步:在dao层,直接写一个mapper接口,然后写一个相应的mapper.xml

①usermapper.java

ArrayList<Users> getUserList();

②usermapper.xml (可以看到在xml里面是直接查询所有记录,而没有limit关键字的,至于分页的操作,pageHelper已经帮我们做了)

<select id="getUserList"  resultType="com.hanpeng.entity.Users">
   select * from tb_users
</select>

现在公众号迁移到这个啦, 不要迷路了,慕仔们,加油哦!
在这里插入图片描述
接下来的一段时间,我会专注Java技术栈,计算机网络,数据结构和算法,操作系统,设计模式,计算机组成原理,数据库原理,设计模式来做分享,欢迎你们和我一起学习,一起提高,Fighting!
本文转载自;https://blog.csdn.net/qq_33609401/article/details/83749083

posted @ 2019-08-15 11:20  抬头不见星空  阅读(135)  评论(0)    收藏  举报