org.apache.ibatis.reflection.ReflectionException: There is no getter for property named '__frch_c...

Caused by: org.apache.ibatis.reflection.ReflectionException: There is no getter for property named '__frch_criterion_1' in 'class com.xxxx.dao.domain.XxxExample'
at org.apache.ibatis.reflection.Reflector.getGetInvoker(Reflector.java:409)
at org.apache.ibatis.reflection.MetaClass.getGetInvoker(MetaClass.java:164)
at org.apache.ibatis.reflection.wrapper.BeanWrapper.getBeanProperty(BeanWrapper.java:162)
at org.apache.ibatis.reflection.wrapper.BeanWrapper.get(BeanWrapper.java:49)
at org.apache.ibatis.reflection.MetaObject.getValue(MetaObject.java:122)
at org.apache.ibatis.reflection.MetaObject.metaObjectForProperty(MetaObject.java:145)
at org.apache.ibatis.reflection.MetaObject.getValue(MetaObject.java:115)
at org.apache.ibatis.executor.BaseExecutor.createCacheKey(BaseExecutor.java:219)
at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:135)
at sun.reflect.GeneratedMethodAccessor108.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at org.apache.ibatis.plugin.Invocation.proceed(Invocation.java:49)

背景

出現(xiàn)該異常的是SSM工程,使用原生mybatis-generator 給業(yè)務(wù)實(shí)體類(Entity,POJO)生成了對(duì)應(yīng)的XxxExample類,并且在mybatis-generator.xml中使用了
<plugin type="org.mybatis.generator.plugins.RowBoundsPlugin"/>

有過相關(guān)開發(fā)經(jīng)驗(yàn)的同學(xué)一定都知道,為業(yè)務(wù)實(shí)體類 生成了對(duì)應(yīng)的XxxExample類,就是為了簡化SQL查詢,使用RowBoundsPlugin就是在查詢時(shí),能方便的進(jìn)行分頁。有了上面這個(gè)2個(gè)工具,就能方便的執(zhí)行xxxMapper.selectByExampleWithRowbounds(example, rowBounds)進(jìn)行分頁+條件查詢了。
而這個(gè) 異常,就是由于這個(gè)RowBoundsPlugin分頁插件導(dǎo)致的。

經(jīng)過反復(fù)試驗(yàn)發(fā)現(xiàn):是把工程的mybatis依賴提升到3.4.2時(shí) 出現(xiàn)的該異常,也就是:

  • mybatis.generator 的版本1.3.5
  • mybatis 的版本3.4.2
  • mybatis-spring 的版本1.3.0
    這套依賴下,RowBoundsPlugin分頁插件出現(xiàn)了該異常。

于是修改工程pom.xml,降低mybatis版本到之前能正常運(yùn)行的

  • mybatis.generator 的版本1.3.5
  • mybatis 的版本3.2.3
  • mybatis-spring 的版本1.2.2
    回退mybatis 到這套版本時(shí),就能跟之前一樣運(yùn)行了。后來發(fā)現(xiàn)降低mybatis版本到3.2.x以前的,也能運(yùn)行。

出現(xiàn)該問題,也折騰了半天。后來請(qǐng)教了一位資深mybatis研究者(一個(gè)mybatis插件的開源者),目前市面上的mybatis分頁插件大體分為2類,一類是支持動(dòng)態(tài)SQL的,如PageHelper;一類是不支持動(dòng)態(tài)SQL的,如RowBoundsPlugin;區(qū)別在于如何完成動(dòng)態(tài)參數(shù)設(shè)置。
我們知道m(xù)ybatis插件本質(zhì)都是攔截器,它在mybatis Executor執(zhí)行SQL之前攔截SQL,設(shè)置分頁參數(shù)等,凡是不支持動(dòng)態(tài)SQL的的分頁插件,都會(huì)出現(xiàn)該異常

在百度搜索這個(gè)異常,發(fā)現(xiàn)國內(nèi)很多使用分頁插件的同學(xué) 確實(shí)出現(xiàn)的這個(gè)問題。而且經(jīng)過這次自己碰到,試驗(yàn)發(fā)現(xiàn)有些分頁插件能否“正常工作” 還和mybatis版本有關(guān);
為了使原先引入分頁插件的代碼正常工作,而回退整個(gè)工程的mybatis版本還是不推薦的,除非萬不得已。
在搭建骨架選擇工具時(shí),應(yīng)該考慮到引入新的插件對(duì)原有工程項(xiàng)目的影響,以及這個(gè)插件的不足。

最后為大家推薦一個(gè)好用的mybatis輔助工具http://www.itdecent.cn/p/5f84624e96bc,不是做分頁用的,而是避免為每一個(gè)實(shí)體類 都生成對(duì)應(yīng)的XxxExample,能做到通用。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容