千家信息网

springboot怎么整合mybatis分页拦截器

发表于:2025-11-10 作者:千家信息网编辑
千家信息网最后更新 2025年11月10日,这篇文章主要介绍"springboot怎么整合mybatis分页拦截器",在日常操作中,相信很多人在springboot怎么整合mybatis分页拦截器问题上存在疑惑,小编查阅了各式资料,整理出简单好
千家信息网最后更新 2025年11月10日springboot怎么整合mybatis分页拦截器

这篇文章主要介绍"springboot怎么整合mybatis分页拦截器",在日常操作中,相信很多人在springboot怎么整合mybatis分页拦截器问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"springboot怎么整合mybatis分页拦截器"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

简介

今天开发时想将自己写好的代码拿来优化,因为不想在开发服弄,怕搞坏了到时候GIT到生产服一大堆问题,然后把它分离到我轮子(工具)项目上,最后运行后发现我获取List的时候很卡至少10秒,我惊了平时也就我的正常版本是800ms左右(不要看它很久,因为数据量很大,也很正常。),前提是我也知道很慢,就等的确需要优化时,我在放出我优化的plus版本,回到10秒哪里,最开始我刚刚接到这个app项目时,在我用 PageHelper.startPage(page, num);(分页),还没等查到的数据封装(PageInfo)就已经分好页了,现在换到轮子上就发现了这个问题,它没有帮我将limit拼接到sql后面,导致我获取全部,再PageInfo分页,数据量庞大导致很卡,最后…

10秒:

正常的:

springboot整合mybatis分页拦截器

分页拦截实际上就是获取sql后将sql拼接limit

pom.xml

                       com.github.pagehelper            pagehelper            5.2.0                            mysql            mysql-connector-java            8.0.21                            org.mybatis.spring.boot            mybatis-spring-boot-starter            1.3.2                             com.alibaba            druid        

yml

spring:  application:    name: spring-cloud-dynamic  datasource:    #类型    type: com.alibaba.druid.pool.DruidDataSource    driver-class-name: com.mysql.cj.jdbc.Driver    url: jdbc:mysql://localhost:3306/f2f?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai    username: root    password:     initial-size: 2    max-idle: 10    min-idle: 1    max-wait: 60000    max-active: 20 #最大空闲连接数    #多久进行一次检测,检测需要关闭的空闲连接    time-between-eviction-tuns-millis: 60000

MybatisConfig

/** * @author lanys * @Description: * @date 23/7/2021 下午8:38 */@Configuration@EnableTransactionManagement@PropertySource(value = "classpath:application.yml", ignoreResourceNotFound = true)public class MybatisConfig implements TransactionManagementConfigurer {    @Value("${mybatis.mapper-locations}")    private String mapper;    @Value("${mybatis.type-aliases-package}")    private String aliases;    @Autowired    private DataSource dataSource;    @Bean(name = "sqlSessionFactory")    public SqlSessionFactory sqlSessionFactory() throws Exception {        SqlSessionFactoryBean bean = new SqlSessionFactoryBean();        // 设置数据源        bean.setDataSource(dataSource);        // 设置xml        bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources(mapper));        // 设置别名        bean.setTypeAliasesPackage(aliases);        // 添加分页插件        bean.setPlugins(new Interceptor[]{pageInterceptor()});        bean.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);        return bean.getObject();    }    /**     * 分页拦截器     * @return     */    private PageInterceptor pageInterceptor() {        PageInterceptor pageInterceptor = new PageInterceptor();        // 详见 com.github.pagehelper.page.PageParams        Properties p = new Properties();        // RowBounds是否进行count查询 - 默认不查询        p.setProperty("rowBoundsWithCount", "true");        // 当设置为true的时候,如果page size设置为0(或RowBounds的limit=0),就不执行分页,返回全部结果        p.setProperty("pageSizeZero", "true");        // 分页合理化        p.setProperty("reasonable", "false");        // 是否支持接口参数来传递分页参数,默认false        p.setProperty("supportMethodsArguments", "true");        // 设置数据库方言 , 也可以不设置,会动态获取        p.setProperty("helperDialect", "mysql");        pageInterceptor.setProperties(p);        return pageInterceptor;    }    @Override    public PlatformTransactionManager annotationDrivenTransactionManager() {        return new DataSourceTransactionManager(dataSource);    }}

测试

自己的其中代码

/**     * 关注列表     * @param userId     * @param page     * @param size     * @return     */    @Override    public List focusList(Long userId, Integer page, Integer size) {        PageHelper.startPage(page, size);        List listByUserId = new ArrayList<>();        try {            //获取自己关注列表            listByUserId = this.dynamicReleaseMapper.getListFocusId(userId);            if (listByUserId == null || listByUserId.size() == 0){                return listByUserId;            }            //List listByUserId = this.dynamicReleaseMapper.getListFocusId(userId).stream().filter(x->(x.getIsPicture()!=2 && x.getIsVideo() !=2)||(x.getIsPicture()==2 && x.getIsVideo() !=2)||(x.getIsPicture()!=2 && x.getIsVideo() ==2)).collect(Collectors.toList());            publicGetDynamicInfo(userId,listByUserId);            //}            log.info("-------获取关注列表-------");            return listByUserId;        } catch (Exception e) {            log.error("获取关注列表异常",e);        }        return listByUserId;    }

想分页要加 PageHelper.startPage(page, size);,否则会默认不分页,也可以自己加limit.

结果(sql语句很长截取一部分):

GROUP BY id ORDER BY create_time desc LIMIT ?

到此,关于"springboot怎么整合mybatis分页拦截器"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

0