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配置双数据源方式,可参考我的另一篇随笔:https://www.cnblogs.com/zblwyj/p/10892903.html
单数据源自己手动书写bean不会的童鞋也可参考此篇文章。
个人学习随笔,若是帮助到您,请给个推荐,或者评论一下下,谢谢了哟。若有不懂之处,请联系QQ:351094262(验证信息:博客园),原创不易,转载请标明出处!