今天在修改一個關(guān)于mybtis語句時,偶然發(fā)現(xiàn)的一個錯誤 There is no getter for property named 'id' in class 'java.lang.String', 糾結(jié)了許久,終于明白了為什么。 原因:Mybatis默認(rèn)采用ONGL解析參數(shù),所以會自動采用對象樹的形式取 string.xxx 值,如果沒在在方法中定義,則會拋異常報錯。當(dāng)然也不是所有的版本會有這個問題,我的項(xiàng)目用的版本比較老。 有兩種解決方案: 方案一: 將對應(yīng)的參數(shù)用 _parameter 的一個參數(shù)替代,在執(zhí)行SQL語句的時候就相當(dāng)預(yù)編譯,此時并不是實(shí)際賦值,相當(dāng)于占位符,這樣就不會發(fā)生這樣的錯誤,直接上圖:
將mapper中的方法參數(shù)用 _parameter來依次替代,也就是上圖中畫紅色線部分。 方法二 在mapper.dao 文件中接口類文件中的方法參數(shù)預(yù)先定義,給參數(shù)加上@Param("id") 類似的注解也能解決這個問題,但需要導(dǎo)入相應(yīng)的注解包和開啟掃描注解 public Object getObjById(@Param("id")String id);
|
|