亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Ibatis中報There is no READABLE property name

系統 1789 0

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

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

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類中的一個屬性名.而不是隨便的一個參數值傳進去.

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

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

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

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

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

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

5.正常情況下,應該盡量使用內聯參數。

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

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

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

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


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产一国产一级毛片视频在线 | 日本免费高清一级毛片 | 久久女人天堂 | 亚洲精品欧洲精品 | 国产精品福利视频一区二区三区 | 黄色的网站在线观看 | 精品国产品欧美日产在线 | 国产精品每日更新在线观看 | 亚洲精品久久九九精品 | 不卡免费播放 | 97色在线播放 | 老师在办公室被躁到白浆 | 日本在线色 | jizzjizz护士xxx | 啪啪毛片 | 在线亚洲精品国产波多野结衣 | 国产精品久久久久久久久久直 | 成人日韩精品 | 免费精品美女久久久久久久久久 | 国产成人综合久久精品亚洲 | 一级a毛片免费观看久久精品 | 久久久久久国产视频 | 精品xxxxxbbbb欧美中文 | 在线 中文字幕 日韩 欧美 | 97视频免费公开成人福利 | 天天射夜夜爱 | 国产欧美亚洲另类第一页 | 四虎影院网址大全 | 中文字幕久久精品波多野结 | 奇米影音四色 | 中文字幕一区二区三区视频在线 | 天天干天天干天天干天天干天天干 | 国产亚洲精品福利片 | 日韩毛片大全 | 色老头老太xxxxbbbb | 国自产拍在线视频天天更新 | 亚洲不卡在线视频 | 亚洲国产成+人+综合 | 99r视频里面只有精品 | 国产欧美日韩精品第二区 | 美女视频国产 |