乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      關(guān)于mybtis 使用過程中發(fā)生There is no getter for property named 'id' in class 'java.lang.String' 錯誤

       小仙女本仙人 2022-05-05 發(fā)布于北京

        今天在修改一個關(guān)于mybtis語句時,偶然發(fā)現(xiàn)的一個錯誤  There is no getter for property named 'id' in class 'java.lang.String', 糾結(jié)了許久,終于明白了為什么。

              原因:Mybatis默認采用ONGL解析參數(shù),所以會自動采用對象樹的形式取 string.xxx 值,如果沒在在方法中定義,則會拋異常報錯。當然也不是所有的版本會有這個問題,我的項目用的版本比較老。

      有兩種解決方案:

      方案一: 將對應(yīng)的參數(shù)用 _parameter 的一個參數(shù)替代,在執(zhí)行SQL語句的時候就相當預(yù)編譯,此時并不是實際賦值,相當于占位符,這樣就不會發(fā)生這樣的錯誤,直接上圖:

       

       將mapper中的方法參數(shù)用 _parameter來依次替代,也就是上圖中畫紅色線部分。

      方法二 

      在mapper.dao 文件中接口類文件中的方法參數(shù)預(yù)先定義,給參數(shù)加上@Param("id") 類似的注解也能解決這個問題,但需要導(dǎo)入相應(yīng)的注解包和開啟掃描注解

      public Object getObjById(@Param("id")String id);

       

        本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多