PageHelper在Mybatis中的使用

 Mybtis中使用PageHelper中分为2中情况,第一种为采用springboot框架自动生成的Bean方式,第二种为自己数据库配置bean方式,以下分别讲解2种方式的使用:

一、采用xml形式配置

1.导入PageHelper的相关jar包

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

2.在项目根目录添加mybatis.xml文件,并新增如下内容

<configuration>
  <plugins>
    <plugin interceptor="com.github.pagehelper.PageInterceptor">
    <!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库 -->
    <!-- <property name="dialect" value="sqlite" /> -->
    </plugin>
   </plugins>
</configuration>

3.在项目的yml配置文件中引用mybatis.xml

# Mybatis配置#mybatis:# mapperLocations: classpath:mapper/**/*.xml# configLocation: classpath:/mybatis.xml

 二、采用JavaBean方式配置

 使用此方式配置则可以不需要mybatis的配置文件,因为此类就相当于之前的配置文件

1.导入相关jar包

2. 创建一个配置类并在配置类中添加一个javaBean,在bean中返回sqlSessionFactory方法中添加如下代码

    @Bean(name = "masterSqlSessionFactory")
    public SqlSessionFactory sqlSessionFactory(@Qualifier("masterDataSource") DataSource dataSource) throws Exception {
        SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
        factoryBean.setDataSource(dataSource);
        factoryBean.setTypeAliasesPackage("com.xuanyin.pojo");
        factoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper/*.xml"));
        
        //添加PageHelper插件  
        Interceptor interceptor = new PageInterceptor();
        Properties properties = new Properties();
        //数据库
        properties.setProperty("helperDialect", "sqlite");
        //是否将参数offset作为PageNum使用
        properties.setProperty("offsetAsPageNum", "true");
        //是否进行count查询
        properties.setProperty("rowBoundsWithCount", "true");
        //是否分页合理化
        properties.setProperty("reasonable", "false");
        interceptor.setProperties(properties);
        factoryBean.setPlugins(new Interceptor[] {interceptor});
        return factoryBean.getObject();
    }

三、分页插件使用方法

方式一:采用Lanmuda表达式形式:不好处理分页查询后的数据

PageInfo<List<Map<String,Object>>>     pageInfo = PageHelper
                    .startPage(dataItem.getPageNum(),dataItem.getPageSize())
                    .doSelectPageInfo(() -> crossCheckExMapper.queryCrossCheckItemAll(dataItem));

方式二:采用正常分页形式:此方法分页查询完可整理分页查询数据,查询语句必须在new PageInfo()之前

        //分页获取数据
        PageHelper.startPage(pageNum, pageSize);
        List<Map<String, Object>> questionnaireIds = questionnaireExMapper.getQuestionnaireIds(idsByOrgIds);
        PageInfo<Map<String, Object>> pageInfo = new PageInfo(questionnaireIds);

        //整理数据的权限组
        List<Map<String, Object>> result = dealData(queryCondition, questionnaireIds, new ArrayList<>());
        pageInfo.setList(result);

提示:springboot配置双数据源的时候,由于是自己书写的bean,故此也可以采用此种方式进行进行分页配置,springboot配置双数据源方式,可参考我的另一篇随笔:SpringBoot中双数据源的配置详解 - 蓝色恋人 - 博客园

 单数据源自己手动书写bean不会的童鞋也可参考此篇文章。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值