mybatis 一對一 映射實體類刃榨、嵌套查詢

一對一

在SysUser 類中增加SysRole字段双仍。
1、sql語句將role.role_name映射到role.roleName上苞轿。

2、還可以在XML 映射文件中配置結(jié)果映射瑟俭。
<resultMap id="userRoleMap" type ="SysUser"〉
<id property="id" column="id"/>
<result property="userName" column="use_name"/>
<result property="userPassword" column="user_password" />
<result property="role.id" column ="role_id"/>
<result property="role.roleName" column="role_name"/>
<result property="role.createTime" column="role_create_time" jdbcType="TIMESTAMP"/>
</resultMap>
為了避免不同表中存在相同的列契邀,如create_time, 在它前面增加了"role_"前綴。

3椭迎、MyBatis是支持resultMap繼承田盈,因此可以簡化上面的resultMap配置
<resultMap id= "userRoleMap" extends= "userMap" type= "SysUser">
<result property= "role.id" column="role_id "/>
<result property= "role.roleName" column= "role_name"/>
<result property= "role.createTime" column ="role_create_time" jdbcType= "TIMESTAMP"/>
</resultMap>

4允瞧、使用resultMap的association標簽配置
<resultMap id= "userRoleMap" extends= "userMap" type= "SysUser">
<association property="role" columnPrefix="role_" javaType="SysRole">
<result property= "id" column="role_id "/>
<result property= "roleName" column= "role_name"/>
<result property= "createTime" column ="create_time" jdbcType= "TIMESTAMP"/>
</association>
</resultMap>
association標簽的屬性property對應(yīng)實體類中的屬性名述暂,必填項。另外我們還配置了columnPrefix="role_"畦韭,在寫SQL的時候艺配,和sys_role表相關(guān)的查詢列的別名都要有"role_"前綴,在內(nèi)部result配置column時转唉,需要去掉前綴。sql:r.id role_id, r.role_name role_role_name, r.create_time role_create_time麦轰。

5款侵、使用association 配置時還可以使用resultMap 屬性配置成一個已經(jīng)存在的resultMap
<resultMap id= "roleMap" type = "SysRole">
<id property="id" column="id"/>
<result property="roleName" column= "role_name"/>
<result property="createTime" column="create_time" jdbcType = "TIMESTAMP"/>
</resultMap>
<resultMap id="userRoleMap" extends= "userMap" type="SysUser">
<association property="role" columnPrefix="role_" resultMap="roleMap"/>
</resultMap>
MyBatis 默認會給 roleMap 添加當前命名空間的前綴侧纯,代碼如下,test.mybatis.simple.mapper.UserMapper.roleMap。目前的 roleMap 是寫在UserMapper.xml中的茂蚓,其實更合理的位置應(yīng)該是在RoleMapper.xml中聋涨。將roleMap移動到RoleMapper.xml中后晾浴,這里的userRoleMap就不能簡單地指定為roleMap了脊凰,而是要修改為以下的樣子狸涌。
<resultMap id="userRoleMap" extends= "userMap" type="SysUser">
<association property="role" columnPrefix="role_" resultMap="test.mybatis.simple.mapper.RoleMapper.roleMap"/>
</resultMap>
上面的情況都是一種情況最岗,這種方式的好處是減少數(shù)據(jù)庫查詢次數(shù),減輕數(shù)據(jù)庫的壓力懒豹。缺點是由于要在應(yīng)用服務(wù)器上將結(jié)果映射到不同的類上脸秽,因此也會增加應(yīng)用服務(wù)器的壓力蝴乔。當一定會使用到嵌套結(jié)果,并且整個復(fù)雜的SQL執(zhí)行速度很快時片酝,建議使用這種方法挖腰。

還可以利用簡單的SQL 通過多次查詢轉(zhuǎn)換為我們需要的結(jié)果曙聂,最后會將結(jié)果組合成一個對象。

<resultMap id = "userRoleMapSelect" extends = "userMap" type= "SysUser">
<association property="role" column="{id=role_id}" select="test.mybatis.simple.mapper.RoleMapper.selectRoleById" />
</resultMap>
<select id="selectUserAndRoleByIdSelect" resultMap="userRoleMapSelect">
select u.id, u.user_name, u.user_password, u.user_email, u.user_info,u.head_img, u.create_time,
ur.role_id
from sys_user u
join sys_user_role ur on u.id = ur.user_id
where u.id= #{id}
</select>
association 屬性 select :另一個查詢的id, MyBatis 會額外執(zhí)行這個查詢断国。
column :列名(或別名)稳衬,將主查詢中列的結(jié)果作為嵌套查詢的參數(shù)坐漏,配置方式如 column = {propl=coll , prop2=col2}。
fetchType :數(shù)據(jù)加載方式街夭,可選值為lazy 和eager,分別為延遲加載和積極加載呈枉,這個配置會覆蓋全局的lazyLoadingEnabled 配置埃碱。

問題:如果主查詢結(jié)果不是1條數(shù)據(jù),而是N條數(shù)據(jù)啃憎,那就會出現(xiàn)N+1問題辛萍。主SQL 會查詢一次,查詢出N 條結(jié)果名党,這N條結(jié)果要各自執(zhí)行一次查詢传睹,那就需要進行N次查詢欧啤。

解決辦法:fetchType="lazy"
<resultMap id = "userRoleMapSelect" extends = "userMap" type= "SysUser">
<association property="role" column="{id=role_id}"
  select="test.mybatis.simple.mapper.RoleMapper.selectRoleById" fetchType="lazy"/>
</resultMap>
<select id="selectUserAndRoleByIdSelect" resultMap="userRoleMapSelect">
  select u.id, u.user_name, u.user_password, u.user_email, u.user_info,u.head_img, u.create_time,
  ur.role_id
from sys_user u
  join sys_user_role ur on u.id = ur.user_id
  where u.id= #{id}
</select >

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末邢隧,一起剝皮案震驚了整個濱河市倒慧,隨后出現(xiàn)的幾起案子按摘,更是在濱河造成了極大的恐慌炫贤,老刑警劉巖兰珍,帶你破解...
    沈念sama閱讀 223,207評論 6 521
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件询吴,死亡現(xiàn)場離奇詭異掠河,居然都是意外死亡亮元,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,455評論 3 400
  • 文/潘曉璐 我一進店門唠摹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來爆捞,“玉大人,你說我怎么就攤上這事跃闹∏断鳎” “怎么了毛好?”我有些...
    開封第一講書人閱讀 170,031評論 0 366
  • 文/不壞的土叔 我叫張陵望艺,是天一觀的道長。 經(jīng)常有香客問我肌访,道長找默,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,334評論 1 300
  • 正文 為了忘掉前任吼驶,我火速辦了婚禮惩激,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己羞反,他們只是感情好,可當我...
    茶點故事閱讀 69,322評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著肛搬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪让腹。 梳的紋絲不亂的頭發(fā)上瓜晤,一...
    開封第一講書人閱讀 52,895評論 1 314
  • 那天足画,我揣著相機與錄音淹辞,去河邊找鬼爷速。 笑死莉给,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播漂洋,決...
    沈念sama閱讀 41,300評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼贝咙,長吁一口氣:“原來是場噩夢啊……” “哼陈症!你這毒婦竟也來了录肯?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,264評論 0 277
  • 序言:老撾萬榮一對情侶失蹤蚤蔓,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體昏苏,經(jīng)...
    沈念sama閱讀 46,784評論 1 321
  • 正文 獨居荒郊野嶺守林人離奇死亡孵构,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,870評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了毒坛。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,989評論 1 354
  • 序言:一個原本活蹦亂跳的男人離奇死亡顶伞,死狀恐怖滑潘,靈堂內(nèi)的尸體忽然破棺而出语卤,到底是詐尸還是另有隱情骂倘,我是刑警寧澤诅需,帶...
    沈念sama閱讀 36,649評論 5 351
  • 正文 年R本政府宣布丐箩,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏玉吁。R本人自食惡果不足惜影斑,卻給世界環(huán)境...
    茶點故事閱讀 42,331評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧征字,春花似錦氮昧、人聲如沸咪辱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,814評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽味咳。三九已至,卻和暖如春匪凉,著一層夾襖步出監(jiān)牢的瞬間堡纬,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,940評論 1 275
  • 我被黑心中介騙來泰國打工祟辟, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留矩距,地道東北人趣兄。 一個月前我還...
    沈念sama閱讀 49,452評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像悼嫉,于是被迫代替她去往敵國和親艇潭。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,995評論 2 361