分享pagehelper报错的问题

分享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>

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值