分享pagehelper报错的问题
问题:
配置pageheler拦截器报错
分析:
PageHelper5.0版本pagehelper继承了PageMethod和实现了Dialect
而报错却说无法将PageHelper转为Interceptor,所以查看源码包的Interceptor
原来的报错的配置文件spring-mybatis.xml代码片段:
<plugins>
<plugin interceptor="com.github.pagehelper.PageHelper">
<!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库-->
<property name="dialect" value="mysql"/>
</plugin>
</plugins>
引入的pom文件内容:
<pagehelper.version>5.0.1</pagehelper.version>
<jsqlparser.version>1.0</jsqlparser.version>
解决办法:
1、将配置文件spring-mybatis.xml改为:
<plugins>
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库-->
<property name="properties" value="mysql"/>
</plugin>
</plugins>
2、将PageHelper5.0版本降级为4.0版本
pom文件内容改为:
<pagehelper.version>4.1.0</pagehelper.version>
总结:
由于pagehelper的5.0版本配置拦截器实现不同,导致配置改变。
另外分享另一种配置方式:
1、在spring-mybatis.xml文件中配置:
代码片段如下:
<bean id="sqlSessionFactoryForm" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSourceForm" />
<!-- 自动扫描mapping.xml文件 -->
<property name="mapperLocations" value="classpath:com/form/*/mapping/*.xml">
</property>
<!-- 打印sql配置 -->
<property name="configLocation" value="classpath:mybatis-config-form.xml">
</property>
<!-- 分页插件 -->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageHelper">
<property name="properties">
<value>
dialect=mysql
</value>
</property>
</bean>
</array>
</property>
</bean>