mybatis的mapper.xml中resultMap標(biāo)簽的使用詳解
1.前言
最近博主在做一個(gè)ssm框架的共享汽車管理系統(tǒng),其中,數(shù)據(jù)庫(kù)字段設(shè)計(jì)的有下劃線方式,a_username,然后在寫mapper.xml里面的sql語(yǔ)句的時(shí)候,一直出現(xiàn)查詢語(yǔ)句查詢的值為null的情況。或者是resultMap標(biāo)簽和駝峰規(guī)則不太明白的同學(xué),可以看這里。
于是順便梳理一下。
2.關(guān)于resultMap
2.1.什么是resultMap?
在mybatis中有一個(gè)resultMap標(biāo)簽,它是為了映射select查詢出來(lái)結(jié)果的集合,其主要作用是將實(shí)體類中的字段與數(shù)據(jù)庫(kù)表中的字段進(jìn)行關(guān)聯(lián)映射。
注意
當(dāng)實(shí)體類中的字段與數(shù)據(jù)庫(kù)表中的字段相同時(shí),可以將resultMap標(biāo)簽中的關(guān)聯(lián)關(guān)系忽略不寫。 當(dāng)實(shí)體類中的字段與數(shù)據(jù)庫(kù)表中的字段不相同時(shí),就需要在resultMap標(biāo)簽中將實(shí)體類字段與數(shù)據(jù)庫(kù)字段一 一進(jìn)行關(guān)聯(lián)映射,或者開啟駝峰規(guī)則,讓它自動(dòng)轉(zhuǎn)換。
3.舉例說(shuō)明
3.1.數(shù)據(jù)庫(kù)與實(shí)體類之間名稱相同
數(shù)據(jù)庫(kù)這么寫:
然后對(duì)應(yīng)寫的實(shí)體類:
在mapper中的查詢方式:
可以看到,是最常規(guī)的sql查詢寫法,這樣就能正常的查詢到數(shù)據(jù)庫(kù)的數(shù)據(jù)。
當(dāng)然這個(gè)時(shí)候開不開啟駝峰規(guī)則都可以,比如在mybatis的配置文件中聲明開啟,也是一樣的效果。
這是為什么呢? 順便說(shuō)幾個(gè)關(guān)于實(shí)體類、數(shù)據(jù)庫(kù)、json格式的知識(shí)。
數(shù)據(jù)庫(kù)字段、索引對(duì)大小寫是不敏感的,駝峰標(biāo)識(shí)無(wú)意義;也就是你開不開啟實(shí)際上都一樣。
json 的規(guī)范格式是帶有下劃線的;比如:
{“id”:”1234” “user_name”:”Lilan”;}
數(shù)據(jù)庫(kù)字段和 bean 之間字段轉(zhuǎn)換,主流 orm 工具都有映射轉(zhuǎn)換支持,比如上圖mybatis中開啟的駝峰規(guī)則;
json 和 bean 之間字段轉(zhuǎn)換,可以使用注解 @JsonProperty,比如寫實(shí)體類的時(shí)候:@JsonProperty('user_name') private String userName;
3.2.數(shù)據(jù)庫(kù)與實(shí)體類之間不相同
比如常見的寫法: 數(shù)據(jù)庫(kù)使用下劃線,與之映射的實(shí)體類中采用駝峰原則。 兩種處理方式:
第一種:開啟駝峰規(guī)則
數(shù)據(jù)庫(kù)如下:
實(shí)體類如下:
解決:
在mybatis的配置文件里加入如上的配置,就基本不用property進(jìn)行字段和實(shí)體和屬性的映射 在進(jìn)行sql查詢和初始化實(shí)體時(shí)mybatis會(huì)為我們自動(dòng)轉(zhuǎn)化,寫sql語(yǔ)句的時(shí)候也不必為有下劃線的字段設(shè)置與實(shí)體類相同的別名。 如未加配置之前的sql查詢語(yǔ)句為(使用別名): select id, user_name as userName, user_sex as userSex, user_age as userAge from user 加入配置之后的sql語(yǔ)句為(直接使用數(shù)據(jù)庫(kù)字段名): select id, user_name, user_sex, user_age from user
Sql如下:
這樣就能直接查詢出數(shù)據(jù)庫(kù)里面的數(shù)據(jù)。
第二種:使用resultMap標(biāo)簽來(lái)映射
比如數(shù)據(jù)庫(kù):
實(shí)體類如下:
然后在mapper.xml中書寫resultMap標(biāo)簽,使得數(shù)據(jù)庫(kù)字段和實(shí)體類 名稱映射。(將實(shí)體類字段與數(shù)據(jù)庫(kù)字段在標(biāo)簽中進(jìn)行一一映射)
源碼如下:
<!-- type指向javabean類,id可自定義 --> <resultMap type='com.zout.entity.Admin' > <id column='aid' property='aid' jdbcType='INTEGER' /> <!-- property對(duì)應(yīng)實(shí)體類的屬性名稱,column為數(shù)據(jù)庫(kù)字段名 --> <result column='a_pid' property='aPid' jdbcType='INTEGER' /> <result column='a_username' property='aUsername' jdbcType='VARCHAR' /> <result column='a_password' property='aPassword' jdbcType='VARCHAR' /> <result column='a_real_name' property='aRealName' jdbcType='VARCHAR' /> <result column='a_phone' property='aPhone' jdbcType='VARCHAR' /> <result column='a_role' property='aRole' jdbcType='VARCHAR' /> <result column='a_icon' property='aIcon' jdbcType='VARCHAR' /> <result column='a_login_time' property='aLoginTime' jdbcType='TIMESTAMP' /> <result column='a_create_time' property='aCreateTime' jdbcType='TIMESTAMP' /> <result column='a_update_time' property='aUpdateTime' jdbcType='TIMESTAMP' /> <result column='a_comment' property='aComment' jdbcType='VARCHAR' /> </resultMap>
提醒:
要記得去mybatis的配置文件中查看是否已經(jīng)去掉駝峰規(guī)則的聲明。使用resultMap,就要禁用駝峰規(guī)則。如果不想改實(shí)體類的話,建議采用resultMap。
如圖:
然后sql如下:
這樣就能獲取到對(duì)應(yīng)的數(shù)據(jù)。sql語(yǔ)句書寫的時(shí)候也可以直接采用數(shù)據(jù)庫(kù)字段名。
4.總結(jié)
第一點(diǎn):
1.mybatis配置文件設(shè)置了這項(xiàng)后,查詢出來(lái)的字段如果帶下劃線,那么就會(huì)去掉下劃線, 然后采用java駝峰規(guī)則。
比如數(shù)據(jù)庫(kù)字段Parent_id,那么查詢出來(lái)后,會(huì)轉(zhuǎn)為parentid,然后去實(shí)體類Category匹配對(duì)應(yīng)的字段。 這個(gè)時(shí)候?qū)嶓w類里就不能寫有下劃線,不然就匹配不上。會(huì)出現(xiàn)查詢結(jié)果都是null值。
第二點(diǎn):
1.當(dāng)進(jìn)行單表簡(jiǎn)單查詢時(shí)且返回值類型是基本類型時(shí),一般mapper的返回類型盡量使用resultType=”xxxx”;
2.當(dāng)進(jìn)行多表關(guān)聯(lián)查詢時(shí),或者說(shuō)xml中定義了相關(guān)的resultMap標(biāo)簽,那么就一般盡量使用resultMap=”xxxx”;
3.在mapper.xml當(dāng)中,resultType和resultMap是不能同時(shí)使用。
第三點(diǎn):
關(guān)于數(shù)據(jù)庫(kù)字段和實(shí)體類名稱不相同的時(shí)候,要么采用resultMap標(biāo)簽, 要么啟用駝峰規(guī)則,但是兩者不能同時(shí)使用。
到此這篇關(guān)于mybatis的mapper.xml中resultMap標(biāo)簽的使用詳解的文章就介紹到這了,更多相關(guān)mybatis resultMap標(biāo)簽使用內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. Mysql入門系列:MYSQL圖像數(shù)據(jù)的處理2. Mysql InnoDB的鎖定機(jī)制實(shí)例詳解3. 淺談Mysql連接數(shù)據(jù)庫(kù)時(shí)host和user的匹配規(guī)則4. MySQL Community Server 5.1.495. MySQL中InnoDB和MyISAM類型的差別6. 全面解讀MySQL主從復(fù)制,從原理到安裝配置7. MySQL分區(qū)的優(yōu)點(diǎn)8. SQLite3的綁定函數(shù)族使用與其注意事項(xiàng)詳解9. MYSQL(電話號(hào)碼,身份證)數(shù)據(jù)脫敏的實(shí)現(xiàn)10. Oracles XMLDB Study NOTE (2)
