mybatis的mapper.xml中resultMap標籤的使用詳解
1.前言
最近博主在做一個ssm框架的共享汽車管理系統,其中,資料庫欄位設計的有下劃線方式,a_username,然後在寫mapper.xml裡面的sql語句的時候,一直出現查詢語句查詢的值為null的情況。或者是resultMap標籤和駝峰規則不太明白的同學,可以看這裡。
於是順便梳理一下。
2.關於resultMap
2.1.什麼是resultMap?
在mybatis中有一個resultMap標籤,它是為了對映select查詢出來結果的集合,其主要作用是將實體類中的欄位與資料庫表中的欄位進行關聯對映。
注意
當實體類中的欄位與資料庫表中的欄位相同時,可以將resultMap標籤中的關聯關係忽略不寫。
3.舉例說明
3.1.資料庫與實體類之間名稱相同
資料庫這麼寫:
然後對應寫的實體類:
在mapper中的查詢方式:
可以看到,是最常規的sql查詢寫法,這樣就能正常的查詢到資料庫的資料。
當然這個時候開不開啟駝峰規則都可以,比如在mybatis的配置檔案中宣告開啟,也是一樣的效果。
這是為什麼呢?
順便說幾個關於實體類、資料庫、json格式的知識。
資料庫欄位、索引對大小寫是不敏感的,駝峰標識無意義;也就是你開不開啟實際上都一樣。
json 的規範格式是帶有下劃線的;比如:
{“id”:”1234” “user_name”:”Lilan”;}
資料庫欄位和 bean 之間欄位轉換,主流 orm 工具都有對映轉換支援,比如上圖mybatis中開啟的駝峰規則;
json 和 bean 之間欄位轉換,可以使用註解 @JsonProperty,比如寫實體類的時候:@JsonProperty("user_name")
private String userName;
3.2.資料庫與實體類之間不相同
比如常見的寫法: 資料庫使用下劃線,與之對映的實體類中採用駝峰原則。
兩種處理方式:
第一種:開啟駝峰規則
資料庫如下:
實體類如下:
解決:
在mybatis的配置檔案里加入如上的配置,就基本不用property進行欄位和實體和屬性的對映
在進行sql查詢和初始化實體時mybatis會為我們自動轉化,寫sql語句的時候也不必為有下劃線的欄位設定與實體類相同的別名。
如未加配置之前的sql查詢語句為(使用別名):
select id,user_name as userName,user_sex as userSex,user_age as userAge from user
加入配置之後的sql語句為(直接使用資料庫欄位名):
select id,user_name,user_sex,user_age from user
Sql如下:
這樣就能直接查詢出資料庫裡面的資料。
第二種:使用resultMap標籤來對映
比如資料庫:
實體類如下:
然後在mapper.xml中書寫resultMap標籤,使得資料庫欄位和實體類
名稱對映。(將實體類欄位與資料庫欄位在標籤中進行一一對映)
原始碼如下:
<!-- type指向javabean類,id可自定義 --> <resultMap id="BaseResultMap" type="com.zout.entity.Admin" > <id column="aid" property="aid" jdbcType="INTEGER" /> <!-- property對應實體類的屬性名稱,column為資料庫欄位名 --> <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的配置檔案中檢視是否已經去掉駝峰規則的宣告。使用resultMap,就要禁用駝峰規則。如果不想改實體類的話,建議採用resultMap。
如圖:
然後sql如下:
這樣就能獲取到對應的資料。sql語句書寫的時候也可以直接採用資料庫欄位名。
4.總結
第一點:
1.mybatis配置檔案設定了這項後,查詢出來的欄位如果帶下劃線,那麼就會去掉下劃線,
然後採用java駝峰規則。
比如資料庫欄位Parent_id,那麼查詢出來後,會轉為parentid,然後去實體類Category匹配對應的欄位。 這個時候實體類裡就不能寫有下劃線,不然就匹配不上。會出現查詢結果都是null值。
第二點:
1.當進行單表簡單查詢時且返回值型別是基本型別時,一般mapper的返回型別儘量使用resultType=”xxxx”;
2.當進行多表關聯查詢時,或者說xml中定義了相關的resultMap標籤,那麼就一般儘量使用resultMap=”xxxx”;
3.在mapper.xml當中,resultType和resultMap是不能同時使用。
第三點:
關於資料庫欄位和實體類名稱不相同的時候,要麼採用resultMap標籤, 要麼啟用駝峰規則,但是兩者不能同時使用。
到此這篇關於mybatis的mapper.xml中resultMap標籤的使用詳解的文章就介紹到這了,更多相關mybatis resultMap標籤使用內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!