日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Ibatis中報There is no READABLE property name

系統(tǒng) 2073 0

困擾了兩天的問題,今天終于得解.原來理解有誤啊.哎....

系統(tǒng)采用struts1.3+spring+ibatis2.3架構..
系統(tǒng)啟動時一直出現(xiàn):
There is no READABLE property named 'nick_name' in class 'com.xlyc.domain.account.Account'
錯誤.
現(xiàn)把配置文件中的一些信息貼出來.

Account.xml

?

< typeAlias? alias ="Account" ?type ="com.xlyc.domain.account.Account" ? />
< resultMap? class ="Account" ?id ="get-accountInfo-result" >
?????????
< result? property ="id" ?column ="id" />
?????????
< result? property ="email" ?column ="email" />
?????????
< result? property ="password" ?column ="password" />
?????????
< result? property ="nickName" ?column ="nick_name" />
?????
</ resultMap >
其中的property屬性中的值是bean(com.xlyc.domain.account.Account)類中的屬性字段

< select? id ="getAccountById" ?parameterClass ="java.lang.Integer"
????????????resultMap
="get-accountInfo-result" >
????????select?id??AS?id,
????????email????????as?email,
????????password????as?password,
????????nick_name???AS?nick_name?
????????from?account?WHERE?id?=?#value#
????
</ select >
SELECT?語句中的AS之后的字段要與RESULTMAP中的COLUMN字段是一致的,而不是與property中的值對應.這一點很重要.

????
< update? id ="updateAccountInfo" ?parameterClass ="Account" >
????????UPDATE?account?set?email=#email#,nick_name=#nickName#?WHERE?id=#id#
????
</ update >

UPDATE語句中的#nickName#中的雙#號之間的值應該為Account類中的一個屬性名.而不是隨便的一個參數(shù)值傳進去.

但如果是int,String,etc類型的話.參數(shù)值應該就value作為參數(shù)傳遞進去.

下面借用別人的一些經驗之談豐富一下本篇內容..

1.在配置ParameterMap的時候,如果傳入的參數(shù)對像是元數(shù)據(jù)類型(int,string etc),那么在配置Parameter元素的時候,property的屬性名使用value。通過這種情況主要使用在為存儲指定參數(shù)的情況下。

2.如果ParameterMap中配置的parameter元素不包含在傳入?yún)?shù)對象中(屬性或IDictionary對象的一個key,value項),將會產生異常,而不管在statement中有沒有用到。

3.在使用parameterMap的extends屬性時,它將會繼承extends值對應的parameterMap配置,并且會繼承它的所有的參數(shù)映射,并且順序是從繼承的那配置為基準開始計算。這個在需要用到extends屬性的時候要特別注意。

4.在為存儲過程傳參過程要特別注意,參數(shù)映射與存儲過程的參數(shù)之間的順序對應要正確。而且必須為提供與存儲過程足夠的參數(shù)(parameter配置足夠多),即使存儲過程的部分參數(shù)已經有默認值了。否則將拋出System.ArgumentOutOfRangeException異常。

5.正常情況下,應該盡量使用內聯(lián)參數(shù)。

一.在使用ResultMap的時候,你要特別注意,如果你在ResultMap中給出的配置字段,但是你返回的數(shù)據(jù)集的時候卻沒有返回這個字段,那程序將出拋出異常。但是相反的,如果你返回了一些字段,卻沒有在ResultMap給出配置定義的話,那么那些字段將不會被處理而不會給你任何的提示,相當沒有查詢出這些字段。你要特別注意這個問題。

?????? 二.如果沒有特別需求的情況,我建議還是把數(shù)據(jù)類的屬性設計成與數(shù)據(jù)庫字段字一樣的比較,這樣如果一般情況下我們都可以不用寫這個ResultMap,事實上如果沒有這樣的特殊要求,那么去寫這個ResultMap仍然是一件非常耗時,并且容易出錯的一份差事。

?????? 三.在使用lazyLoad的時候要特別注意,不是什么類型的數(shù)據(jù)都可以lazyLoad的,只有是實現(xiàn)的IList的接口的類型,并且數(shù)據(jù)類的屬性定義為IList類型的字段才能被lazyLoad。(關于是否只有IList類型的屬性才能被lazyLoad的問題還需要探討一下,因為就我使用的經驗只有這種類型才可以,甚至是Generic版的IList都不支持)。而且你在使用它的時候,還不能把這個IList類型的屬性轉換成你真正的數(shù)據(jù)類型。因為在運行時,這個屬性會被包裝成一個動態(tài)的類型,這個動態(tài)類型仍然實現(xiàn)了IList接口,就是因為這個動態(tài)類型才擴展了我們可以lazyLoad的功能。這時候在程序中使用的是運行時的動態(tài)類型所以你沒辦法進行強類型轉換。

Ibatis中報There is no READABLE property named錯誤.得解


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 龙陵县| 深州市| 新巴尔虎右旗| 昔阳县| 壤塘县| 巴青县| 开鲁县| 宝兴县| 大新县| 五华县| 砚山县| 江西省| 宜兰市| 永川市| 逊克县| 德保县| 桐乡市| 永德县| 共和县| 成武县| 达日县| 手机| 临清市| 庆阳市| 翼城县| 泗阳县| 赣州市| 许昌市| 十堰市| 上林县| 贺州市| 陆川县| 宣城市| 漳浦县| 化德县| 蓝田县| 郑州市| 霍林郭勒市| 黎川县| 墨玉县| 雅安市|