亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MyBatis中resultMap和resultType的區(qū)別詳解

 更新時間:2020年07月03日 10:23:40   作者:Leesin Dong  
這篇文章主要介紹了MyBatis中resultMap和resultType的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

總結(jié)

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

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


單表查詢: resultMap:當(dāng)使用resultMap做SQL語句返回結(jié)果類型處理時,通常需要在mapper.xml中定義resultMap進(jìn)行pojo和相應(yīng)表字段的對應(yīng)。

訂單查詢關(guān)聯(lián)用戶的resultMap

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

<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersUserResultMap">
  <!-- 配置映射的訂單信息 -->
  <!-- id:指定查詢列中的唯 一標(biāo)識,訂單信息的中的唯 一標(biāo)識,如果有多個列組成唯一標(biāo)識,配置多個id
    column:訂單信息的唯 一標(biāo)識 列
    property:訂單信息的唯 一標(biāo)識 列所映射到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>

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

訂單查詢關(guān)聯(lián)用戶的resultMap

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

<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersUserResultMap">
  <!-- 配置映射的訂單信息 -->
  <!-- id:指定查詢列中的唯 一標(biāo)識,訂單信息的中的唯 一標(biāo)識,如果有多個列組成唯一標(biāo)識,配置多個id
    column:訂單信息的唯 一標(biāo)識 列
    property:訂單信息的唯 一標(biāo)識 列所映射到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/>
  
  <!-- 配置映射的關(guān)聯(lián)的用戶信息 -->
  <!-- association:用于映射關(guān)聯(lián)查詢單個對象的信息
  property:要將關(guān)聯(lián)查詢的用戶信息映射到Orders中哪個屬性
   -->
  <association property="user" javaType="cn.itcast.mybatis.po.User">
    <!-- id:關(guān)聯(lián)查詢用戶的唯 一標(biāo)識
    column:指定唯 一標(biāo)識用戶信息的列
    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>

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

訂單及訂單明細(xì)的resultMap

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

<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersAndOrderDetailResultMap" extends="OrdersUserResultMap">
  <!-- 訂單信息 -->
  <!-- 用戶信息 -->
  <!-- 使用extends繼承,不用在中配置訂單信息和用戶信息的映射 -->
  
  
  <!-- 訂單明細(xì)信息
  一個訂單關(guān)聯(lián)查詢出了多條明細(xì),要使用collection進(jìn)行映射
  collection:對關(guān)聯(lián)查詢到多條記錄映射到集合對象中
  property:將關(guān)聯(lián)查詢到多條記錄映射到cn.itcast.mybatis.po.Orders哪個屬性
  ofType:指定映射到list集合屬性中pojo的類型
   -->
   <collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail">
     <!-- id:訂單明細(xì)唯 一標(biāo)識
     property:要將訂單明細(xì)的唯 一標(biāo)識 映射到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:

作用:
將關(guān)聯(lián)查詢信息映射到一個pojo對象中

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

比如:查詢訂單及關(guān)聯(lián)用戶信息
使用resultType無法查詢結(jié)果映射到pojo對象的pojo屬性中,根據(jù)對結(jié)構(gòu)集查詢遍歷的需要選擇使用resultType還是resultMap。

collection:

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

到此這篇關(guān)于mybaties中resultMap和resultType的區(qū)別詳解的文章就介紹到這了,更多相關(guān)mybaties中resultMap和resultType的區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java中HashMap和TreeMap的區(qū)別深入理解

    Java中HashMap和TreeMap的區(qū)別深入理解

    首先介紹一下什么是Map。在數(shù)組中我們是通過數(shù)組下標(biāo)來對其內(nèi)容索引的,而在Map中我們通過對象來對對象進(jìn)行索引,用來索引的對象叫做key,其對應(yīng)的對象叫做value
    2012-12-12
  • Spring Boot中使用jdbctemplate 操作MYSQL數(shù)據(jù)庫實例

    Spring Boot中使用jdbctemplate 操作MYSQL數(shù)據(jù)庫實例

    本篇文章主要介紹了Spring Boot中使用jdbctemplate 操作MYSQL數(shù)據(jù)庫實例,具有一定的參考價值,有興趣的可以了解一下。
    2017-04-04
  • 最簡單的在IntelliJ IDEA導(dǎo)入一個本地項目教程(圖文)

    最簡單的在IntelliJ IDEA導(dǎo)入一個本地項目教程(圖文)

    這篇文章主要介紹了最簡單的在IntelliJ IDEA導(dǎo)入一個本地項目教程(圖文),文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • Springboot項目Maven依賴沖突的問題解決

    Springboot項目Maven依賴沖突的問題解決

    使用Spring Boot和Maven進(jìn)行項目開發(fā)時,依賴沖突是一個常見的問題,本文就來介紹一下Springboot項目Maven依賴沖突的問題解決,具有一定的參考價值,感興趣的可以了解一下
    2024-07-07
  • Java數(shù)據(jù)結(jié)構(gòu)之棧與綜合計算器的實現(xiàn)

    Java數(shù)據(jù)結(jié)構(gòu)之棧與綜合計算器的實現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了Java數(shù)據(jù)結(jié)構(gòu)中棧與綜合計算器的實現(xiàn),文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以了解一下
    2022-10-10
  • Java中Arrays數(shù)組工具類的基本使用詳解

    Java中Arrays數(shù)組工具類的基本使用詳解

    Arrays類中的方法都是static修飾的靜態(tài)方法,在使用的時候可以直接使用類名進(jìn)行調(diào)用,而"不用"使用對象來調(diào)用(注意:是"不用"?而不是?"不能"),這篇文章主要給大家介紹了關(guān)于Java中Arrays數(shù)組工具類的基本使用,需要的朋友可以參考下
    2021-12-12
  • Java中String、StringBuffer和StringBuilder的區(qū)別與使用場景

    Java中String、StringBuffer和StringBuilder的區(qū)別與使用場景

    在Java編程中,String、StringBuffer和StringBuilder是用于處理字符串的常見類,它們在可變性、線程安全性和性能方面有所不同,具有一定的參考價值,感興趣的可以了解一下
    2024-05-05
  • 解決Java J2EE亂碼問題的方法

    解決Java J2EE亂碼問題的方法

    這篇文章主要為大家詳細(xì)介紹了解決Java J2EE亂碼問題的方法的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • 在Android的應(yīng)用中實現(xiàn)網(wǎng)絡(luò)圖片異步加載的方法

    在Android的應(yīng)用中實現(xiàn)網(wǎng)絡(luò)圖片異步加載的方法

    這篇文章主要介紹了在Android的應(yīng)用中實現(xiàn)網(wǎng)絡(luò)圖片異步加載的方法,一定程度上有助于提高安卓程序的使用體驗,需要的朋友可以參考下
    2015-07-07
  • JVM GC 垃圾收集梳理總結(jié)

    JVM GC 垃圾收集梳理總結(jié)

    這篇文章主要介紹了JVM GC 垃圾收集梳理總結(jié),GC是一種自動的存儲管理機(jī)制。當(dāng)一些被占用的內(nèi)存不再需要時,就應(yīng)該予以釋放,這種存儲資源管理,稱為垃圾回收
    2022-07-07

最新評論