久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

mybatis的mapper.xml中resultMap標簽的使用詳解

瀏覽:201日期:2023-10-23 18:28:52

1.前言

最近博主在做一個ssm框架的共享汽車管理系統(tǒng),其中,數(shù)據(jù)庫字段設計的有下劃線方式,a_username,然后在寫mapper.xml里面的sql語句的時候,一直出現(xiàn)查詢語句查詢的值為null的情況。或者是resultMap標簽和駝峰規(guī)則不太明白的同學,可以看這里。

于是順便梳理一下。

2.關于resultMap

2.1.什么是resultMap

在mybatis中有一個resultMap標簽,它是為了映射select查詢出來結果的集合,其主要作用是將實體類中的字段與數(shù)據(jù)庫表中的字段進行關聯(lián)映射。

注意

當實體類中的字段與數(shù)據(jù)庫表中的字段相同時,可以將resultMap標簽中的關聯(lián)關系忽略不寫。 當實體類中的字段與數(shù)據(jù)庫表中的字段不相同時,就需要在resultMap標簽中將實體類字段與數(shù)據(jù)庫字段一 一進行關聯(lián)映射,或者開啟駝峰規(guī)則,讓它自動轉換。

3.舉例說明

3.1.數(shù)據(jù)庫與實體類之間名稱相同

數(shù)據(jù)庫這么寫:

mybatis的mapper.xml中resultMap標簽的使用詳解 

然后對應寫的實體類:

mybatis的mapper.xml中resultMap標簽的使用詳解

在mapper中的查詢方式:

mybatis的mapper.xml中resultMap標簽的使用詳解

可以看到,是最常規(guī)的sql查詢寫法,這樣就能正常的查詢到數(shù)據(jù)庫的數(shù)據(jù)。

當然這個時候開不開啟駝峰規(guī)則都可以,比如在mybatis的配置文件中聲明開啟,也是一樣的效果。

mybatis的mapper.xml中resultMap標簽的使用詳解

這是為什么呢? 順便說幾個關于實體類、數(shù)據(jù)庫、json格式的知識。

數(shù)據(jù)庫字段、索引對大小寫是不敏感的,駝峰標識無意義;也就是你開不開啟實際上都一樣。

json 的規(guī)范格式是帶有下劃線的;比如:

{“id”:”1234” “user_name”:”Lilan”;}

數(shù)據(jù)庫字段和 bean 之間字段轉換,主流 orm 工具都有映射轉換支持,比如上圖mybatis中開啟的駝峰規(guī)則;

json 和 bean 之間字段轉換,可以使用注解 @JsonProperty,比如寫實體類的時候:@JsonProperty('user_name') private String userName;

3.2.數(shù)據(jù)庫與實體類之間不相同

比如常見的寫法: 數(shù)據(jù)庫使用下劃線,與之映射的實體類中采用駝峰原則。 兩種處理方式:

第一種:開啟駝峰規(guī)則

數(shù)據(jù)庫如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

實體類如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

解決:

mybatis的mapper.xml中resultMap標簽的使用詳解

在mybatis的配置文件里加入如上的配置,就基本不用property進行字段和實體和屬性的映射 在進行sql查詢和初始化實體時mybatis會為我們自動轉化,寫sql語句的時候也不必為有下劃線的字段設置與實體類相同的別名。 如未加配置之前的sql查詢語句為(使用別名): select id, user_name as userName, user_sex as userSex, user_age as userAge from user 加入配置之后的sql語句為(直接使用數(shù)據(jù)庫字段名): select id, user_name, user_sex, user_age from user

Sql如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

這樣就能直接查詢出數(shù)據(jù)庫里面的數(shù)據(jù)。

第二種:使用resultMap標簽來映射

比如數(shù)據(jù)庫:

mybatis的mapper.xml中resultMap標簽的使用詳解

實體類如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

然后在mapper.xml中書寫resultMap標簽,使得數(shù)據(jù)庫字段和實體類 名稱映射。(將實體類字段與數(shù)據(jù)庫字段在標簽中進行一一映射)

mybatis的mapper.xml中resultMap標簽的使用詳解

源碼如下:

<!-- type指向javabean類,id可自定義 --> <resultMap type='com.zout.entity.Admin' > <id column='aid' property='aid' jdbcType='INTEGER' /> <!-- property對應實體類的屬性名稱,column為數(shù)據(jù)庫字段名 --> <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ī)則。如果不想改實體類的話,建議采用resultMap。

如圖:

mybatis的mapper.xml中resultMap標簽的使用詳解

然后sql如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

這樣就能獲取到對應的數(shù)據(jù)。sql語句書寫的時候也可以直接采用數(shù)據(jù)庫字段名。

4.總結

第一點:

1.mybatis配置文件設置了這項后,查詢出來的字段如果帶下劃線,那么就會去掉下劃線, 然后采用java駝峰規(guī)則。

比如數(shù)據(jù)庫字段Parent_id,那么查詢出來后,會轉為parentid,然后去實體類Category匹配對應的字段。 這個時候實體類里就不能寫有下劃線,不然就匹配不上。會出現(xiàn)查詢結果都是null值。

第二點:

1.當進行單表簡單查詢時且返回值類型是基本類型時,一般mapper的返回類型盡量使用resultType=”xxxx”;

2.當進行多表關聯(lián)查詢時,或者說xml中定義了相關的resultMap標簽,那么就一般盡量使用resultMap=”xxxx”;

3.在mapper.xml當中,resultType和resultMap是不能同時使用。

第三點:

關于數(shù)據(jù)庫字段和實體類名稱不相同的時候,要么采用resultMap標簽, 要么啟用駝峰規(guī)則,但是兩者不能同時使用。

到此這篇關于mybatis的mapper.xml中resultMap標簽的使用詳解的文章就介紹到這了,更多相關mybatis resultMap標簽使用內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

相關文章:
主站蜘蛛池模板: 国产精品久久久久久久免费大片 | 在线手机电影 | 有码在线| 国产a久久精品一区二区三区 | 国产污视频在线 | 欧美成人高清视频 | 免费在线成人 | 国产视频亚洲精品 | 九九久久久 | 最近最新中文字幕 | 91看片| 一区免费看 | 久久久久久久成人 | 99热.com| 色黄网站 | 高清国产午夜精品久久久久久 | 精品国产91亚洲一区二区三区www | 国产精品99一区二区三区 | 亚洲一区二区三区在线播放 | 久久99精品国产99久久6男男 | 密色视频 | 亚洲午夜视频在线观看 | 欧美日韩福利 | 久草资源在线视频 | 99久久综合精品五月天 | 亚洲欧美日韩一区 | 精品在线播放 | 视频成人免费 | 国产精品一区二区在线 | 久久精品亚洲一区二区 | 黄色的视频免费 | 男人的天堂在线视频 | 欧美日韩综合视频 | 超碰激情| 日本精品二区 | 国产精品日韩欧美 | 91社区在线播放 | 婷婷综合激情 | 国产视频大全 | 91精品国产高清一区二区三区 | 欧美精产国品一二三区 |