SSM框架中分页插件PageInterceptor

 

 

复制代码
package com.ita.config;

import com.github.pagehelper.PageInterceptor;
import org.apache.ibatis.plugin.Interceptor;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.mapper.MapperScannerConfigurer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;

import javax.sql.DataSource;
import java.util.Properties;

public class MyBatisConfig {
    /**配置PageInterceptor分页插件*/
    @Bean
    public PageInterceptor getPageInterceptor() {
        PageInterceptor pageIntercptor = new PageInterceptor();
        Properties properties = new Properties();
        properties.setProperty("value", "true");
        pageIntercptor.setProperties(properties);
        return pageIntercptor;
    }
    /*
    定义MyBatis的核心连接工厂bean,
    等同于<bean class="org.mybatis.spring.SqlSessionFactoryBean">
     参数使用自动装配的形式加载dataSource,
    为set注入提供数据源,dataSource来源于JdbcConfig中的配置
     */
    @Bean
    public SqlSessionFactoryBean getSqlSessionFactoryBean(@Autowired DataSource dataSource,@Autowired PageInterceptor pageIntercptor){
        SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean();
        //等同于<property name="dataSource" ref="dataSource"/>
        ssfb.setDataSource(dataSource);
        Interceptor[] plugins={pageIntercptor};
        ssfb.setPlugins(plugins);
        return ssfb;
    }
  
}
复制代码

 

 1.在 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>
复制代码


2.在 spring-mybatis.xml 中添加如下

复制代码
<!-- 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>
复制代码

 

userDao

ArrayList<Users> getUserList();

mapping.xml

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



userService

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());
}

controller

@RequestMapping("pageHelperTest")
public void getList(){
   userService.test();
}


REF

https://blog.csdn.net/qq_39200980/article/details/104895549

https://blog.csdn.net/qq_33609401/article/details/83749083

https://blog.csdn.net/qq_39765090/article/details/87174950

posted @   emanlee  阅读(1047)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
历史上的今天:
2011-12-26 由于这台计算机没有终端服务器客户端访问许可证,远程会话被中断,请跟服务器管理员联系
点击右上角即可分享
微信分享提示