91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MyBatis中resultMap和resultType有什么不同

發布時間:2020-07-03 13:43:02 來源:億速云 閱讀:280 作者:清晨 欄目:開發技術

小編給大家分享一下MyBatis中resultMap和resultType有什么不同,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!

基本映射 :(resultType)使用resultType進行輸出映射,只有查詢出來的列名和pojo中的屬性名一致,該列才可以映射成功。(數據庫,實體,查詢字段,這些全部都得一一對應)高級映射 :(resultMap) 如果查詢出來的列名和pojo的屬性名不一致,通過定義一個resultMap對列名和pojo屬性名之間作一個映射關系。(高級映射,字段名稱可以不一致,通過映射來實現

resultType和resultMap功能類似 ,都是返回對象信息 ,但是resultMap要更強大一些 ,可自定義。因為resultMap要配置一下,表和類的一一對應關系,所以說就算你的字段名和你的實體類的屬性名不一樣也沒關系,都會給你映射出來,但是,resultType就比較雞肋了,必須字段名一樣,比如說 cId和c_id 這種的都不能映射 。下面介紹幾個常用的映射關系:

MyBatis中resultMap和resultType有什么不同

MyBatis中resultMap和resultType有什么不同

單表查詢: resultMap:當使用resultMap做SQL語句返回結果類型處理時,通常需要在mapper.xml中定義resultMap進行pojo和相應表字段的對應。

訂單查詢關聯用戶的resultMap

將整個查詢的結果映射到cn.itcast.mybatis.po.Orders中

<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersUserResultMap">
  <!-- 配置映射的訂單信息 -->
  <!-- id:指定查詢列中的唯 一標識,訂單信息的中的唯 一標識,如果有多個列組成唯一標識,配置多個id
    column:訂單信息的唯 一標識 列
    property:訂單信息的唯 一標識 列所映射到Orders中哪個屬性
   -->
  <id column="id" property="id"/>
  <result column="user_id" property="userId"/>
  <result column="number" property="number"/>
  <result column="createtime" property="createtime"/>
  <result column="note" property="note"/>    
</resultMap>

關聯查詢(一對一):resultMap對于一對一表連接的處理方式通常為在主表的pojo中添加嵌套另一個表的pojo,然后在mapper.xml中采用association節點元素進行對另一個表的連接處理。例如

訂單查詢關聯用戶的resultMap

將整個查詢的結果映射到cn.itcast.mybatis.po.Orders中

<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersUserResultMap">
  <!-- 配置映射的訂單信息 -->
  <!-- id:指定查詢列中的唯 一標識,訂單信息的中的唯 一標識,如果有多個列組成唯一標識,配置多個id
    column:訂單信息的唯 一標識 列
    property:訂單信息的唯 一標識 列所映射到Orders中哪個屬性
   -->
  <id column="id" property="id"/>
  <result column="user_id" property="userId"/>
  <result column="number" property="number"/>
  <result column="createtime" property="createtime"/>
  <result column="note" property=note/>
  
  <!-- 配置映射的關聯的用戶信息 -->
  <!-- association:用于映射關聯查詢單個對象的信息
  property:要將關聯查詢的用戶信息映射到Orders中哪個屬性
   -->
  <association property="user" javaType="cn.itcast.mybatis.po.User">
    <!-- id:關聯查詢用戶的唯 一標識
    column:指定唯 一標識用戶信息的列
    javaType:映射到user的哪個屬性
     -->
    <id column="user_id" property="id"/>
    <result column="username" property="username"/>
    <result column="sex" property="sex"/>
    <result column="address" property="address"/>
  
  </association>
</resultMap>

關聯查詢(一對多):resultMap的處理方式為在訂單表數據的pojo中添加一個list,list中為訂單明細表的屬性,在mapper.xml中采用如下的處理方式:

訂單及訂單明細的resultMap

使用extends繼承,不用在中配置訂單信息和用戶信息的映射

<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersAndOrderDetailResultMap" extends="OrdersUserResultMap">
  <!-- 訂單信息 -->
  <!-- 用戶信息 -->
  <!-- 使用extends繼承,不用在中配置訂單信息和用戶信息的映射 -->
  
  
  <!-- 訂單明細信息
  一個訂單關聯查詢出了多條明細,要使用collection進行映射
  collection:對關聯查詢到多條記錄映射到集合對象中
  property:將關聯查詢到多條記錄映射到cn.itcast.mybatis.po.Orders哪個屬性
  ofType:指定映射到list集合屬性中pojo的類型
   -->
   <collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail">
     <!-- id:訂單明細唯 一標識
     property:要將訂單明細的唯 一標識 映射到cn.itcast.mybatis.po.Orderdetail的哪個屬性
      -->
     <id column="orderdetail_id" property="id"/>
     <result column="items_id" property="itemsId"/>
     <result column="items_num" property="itemsNum"/>
     <result column="orders_id" property="ordersId"/>
   </collection>
</resultMap>

association:

作用:
將關聯查詢信息映射到一個pojo對象中

場合:
為了方便查詢關聯查詢可以使用assocation將關聯查詢信息映射為用戶對象的pojo屬性中。

比如:查詢訂單及關聯用戶信息
使用resultType無法查詢結果映射到pojo對象的pojo屬性中,根據對結構集查詢遍歷的需要選擇使用resultType還是resultMap。

collection:

作用:
將關聯查詢信息映射到一個list集合中。
場合:
為了方便查詢遍歷關聯信息可以使用cellection將關聯信息映射到list集合中。
比如:
查詢用戶權限范圍模塊及模塊下的菜單,可使用collection將模塊映射到模塊list中將菜單列表映射到模塊對象的菜單list屬性中,這樣做的目的也是方便對查詢結果集進行遍歷如果使用resultType無法將查詢結果映射到list集合中

看完了這篇文章,相信你對MyBatis中resultMap和resultType有什么不同有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

彰化县| 山阴县| 永昌县| 从化市| 碌曲县| 廊坊市| 布尔津县| 金平| 稻城县| 嘉定区| 平遥县| 澄江县| 昔阳县| 大荔县| 新平| 马鞍山市| 利川市| 靖州| 偏关县| 桃源县| 吉木乃县| 青浦区| 陵川县| 土默特左旗| 淳安县| 宜兴市| 昌乐县| 仁寿县| 湟源县| 华蓥市| 英德市| 光山县| 江都市| 花莲市| 西充县| 垣曲县| 通渭县| 潜江市| 梅河口市| 岗巴县| 文登市|