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類材彪,就是為了簡(jiǎn)化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.reibang.com/p/5f84624e96bc,不是做分頁用的,而是避免為每一個(gè)實(shí)體類 都生成對(duì)應(yīng)的XxxExample,能做到通用厚者。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末熙宇,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌互躬,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,525評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件竭缝,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡膜蛔,警方通過查閱死者的電腦和手機(jī)皂股,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門悍募,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了谨垃?”我有些...
    開封第一講書人閱讀 164,862評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵匙隔,是天一觀的道長。 經(jīng)常有香客問我,道長曲横,這世上最難降的妖魔是什么蚊丐? 我笑而不...
    開封第一講書人閱讀 58,728評(píng)論 1 294
  • 正文 為了忘掉前任鞋诗,我火速辦了婚禮秀仲,結(jié)果婚禮上覆劈,老公的妹妹穿的比我還像新娘坤候。我一直安慰自己白筹,他們只是感情好系馆,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般谓媒。 火紅的嫁衣襯著肌膚如雪抢野。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,590評(píng)論 1 305
  • 那天叉跛,我揣著相機(jī)與錄音,去河邊找鬼赫冬。 笑死哄啄,一個(gè)胖子當(dāng)著我的面吹牛雅任,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播咨跌,決...
    沈念sama閱讀 40,330評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼沪么,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了锌半?” 一聲冷哼從身側(cè)響起禽车,我...
    開封第一講書人閱讀 39,244評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎刊殉,沒想到半個(gè)月后殉摔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡记焊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評(píng)論 3 336
  • 正文 我和宋清朗相戀三年逸月,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遍膜。...
    茶點(diǎn)故事閱讀 40,001評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡碗硬,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出捌归,到底是詐尸還是另有隱情肛响,我是刑警寧澤岭粤,帶...
    沈念sama閱讀 35,723評(píng)論 5 346
  • 正文 年R本政府宣布惜索,位于F島的核電站,受9級(jí)特大地震影響剃浇,放射性物質(zhì)發(fā)生泄漏巾兆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評(píng)論 3 330
  • 文/蒙蒙 一虎囚、第九天 我趴在偏房一處隱蔽的房頂上張望角塑。 院中可真熱鬧,春花似錦淘讥、人聲如沸圃伶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽窒朋。三九已至,卻和暖如春蝗岖,著一層夾襖步出監(jiān)牢的瞬間侥猩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評(píng)論 1 270
  • 我被黑心中介騙來泰國打工抵赢, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留欺劳,地道東北人唧取。 一個(gè)月前我還...
    沈念sama閱讀 48,191評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像划提,于是被迫代替她去往敵國和親枫弟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評(píng)論 2 355