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

Mybatis中resultMap的Colum和property屬性詳解

 更新時間:2022年01月10日 11:23:06   作者:愛吃小牛奶  
這篇文章主要介紹了Mybatis中resultMap的Colum和property屬性,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教。

resultMap的Colum和property屬性

1: resultMap標簽

當我們的數(shù)據(jù)庫字段與實體類的屬性不一致時,就需要使用該標簽進行一一映射。

2:使用情況

2.1 簡單查詢

 <resultMap id="這個resultMap的id" type="對應實體類的全限定類名">
         <id column="id" property="id"></id>
        <result column="username" property="name"></result>
        <result column="author" property="author"></result>
        <result column="number" property="number"></result>
       .............
       colum對應數(shù)據(jù)庫的字段,property對應實體類的屬性
    </resultMap>

他表示對數(shù)據(jù)按照什么樣的規(guī)則進行一一映射,如:

  <!-- 根據(jù)編號查找書籍-->
    <select id="SelectbooksByNumber" parameterType="String"  resultMap="名字">
        select * from book where number=#{number};
    </select>

上面的查找結果按照你給的resultMap的對應規(guī)則進行映射。

2.2 一對一

需要注意的是你sql語句查出來的列名稱是別名,那你就要填別名,就不是你數(shù)據(jù)庫的列名稱了。

返回結果:User
User中含有Role屬性集合 一對多的關系
JavaType是用來指定pojo中屬性的類型

2.3 一對多

同樣和一對一 一樣需要注意列名稱。

返回結果:User
User中含有Role屬性集合 一對多的關系
JavaType是用來指定pojo中屬性的類型,
ofType指定的是 映射到list集合屬性中pojo的類型
其中Role屬性集合為List

pojo

public class User implements Serializable {
    private Integer id;
    private String username;
    private String password;
    private String salt;
    private Integer status; // 用戶狀態(tài) 0: 正常   1:禁用   2:鎖定

    //角色集合
    private List<Role> roles;

role表

在這里插入圖片描述

user表

在這里插入圖片描述

user與role的映射表

在這里插入圖片描述

resultMap對column和property的理解

首先,先看看這張圖,看能不能一下看明白:

select元素有很多屬性(這里說用的比較多的)

  • id:命名空間唯一標識,可以被用來引用這條語句
  • parameterType:將會傳入這條語句的參數(shù)類的完全限定名或者別名
  • resultType:從這條語句要返回的期望類型的類的完全限定名或別名(這里注意下集合類型,應該是集合可以包含的類型,不能是集合本身),重要:使用resultType或resultMap,但不能同時使用。
  • resultMap:命名引用外部的resultMap,其名稱要和外部的resultMap元素的ID名稱一致,用于映射其結果到實體類指定對象中。

什么時候我們知道使用resultMap,什么時候又使用resultType呢?

①當去select一張表時,可以使用resultType,這些情況下,MyBatis會在幕后自動創(chuàng)建一個ReusltMap,基于屬性名來映射到JavaBean屬性上

②所以在使用resultMap時,就必須要寫上resultMap相對應的xml

③為了方便我們開發(fā)出錯,在沒有特別要求的情況下,column名可以完全和property名稱一致,否則當我們沒有對應上的時候,數(shù)據(jù)庫匹配不到,會將某某參數(shù)值變?yōu)榇髮?,導致我們本來獲取小寫的參數(shù)名,結果沒有獲取到,后臺報錯,得不償失??!

最后說下

sql中比如,有 andm.id = #{id ,jdbcType=VARCHAR } 要標明jdbcType為什么呢?

解釋:

如果你映射了一個javabean,MyBatis通常可以斷定類型(項目里好多都要寫,我也不知道為啥),然而,如果你映射到的是比如:HashMap,那么應該明確指定的jdbcType來保證所需的行為

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 詳解Maven項目Dependencies常見報錯及解決方案

    詳解Maven項目Dependencies常見報錯及解決方案

    這篇文章主要介紹了詳解Maven項目Dependencies常見報錯及解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • SpringBoot @FixMethodOrder 如何調(diào)整單元測試順序

    SpringBoot @FixMethodOrder 如何調(diào)整單元測試順序

    這篇文章主要介紹了SpringBoot @FixMethodOrder 調(diào)整單元測試順序方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 分享幾個提高Java性能的高效用法

    分享幾個提高Java性能的高效用法

    這篇文章主要介紹了分享幾個提高Java性能的高效用法 ,需要的朋友可以參考下
    2014-10-10
  • java數(shù)據(jù)庫連接池的特點及步驟

    java數(shù)據(jù)庫連接池的特點及步驟

    大家好,本篇文章主要講的是數(shù)據(jù)庫連接池的特點及步驟,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Java的Hibernate框架中的基本映射用法講解

    Java的Hibernate框架中的基本映射用法講解

    映射是Hibernate框架操作數(shù)據(jù)庫數(shù)據(jù)的重要特性之一,這里我們來看一下Java的Hibernate框架中的基本映射用法講解,包括最基本的單向一對一與多對一映射關系等:
    2016-07-07
  • Java實現(xiàn)簡易學籍管理系統(tǒng)

    Java實現(xiàn)簡易學籍管理系統(tǒng)

    這篇文章主要為大家詳細介紹了Java實現(xiàn)簡易學籍管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 解決MyEclipse中Maven設置jdk版本jdk1.8報錯問題

    解決MyEclipse中Maven設置jdk版本jdk1.8報錯問題

    今天安裝了jdk1.8、tomcat8、和maven3.5.2,弄好后在myeclipse新建了一個maven項目,項目默認是jdk1.5,改成jdk1.8后項目報錯
    2018-10-10
  • JVM運行時數(shù)據(jù)區(qū)原理解析

    JVM運行時數(shù)據(jù)區(qū)原理解析

    這篇文章主要介紹了JVM運行時數(shù)據(jù)區(qū)原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • Spring Boot整合web層實現(xiàn)過程詳解

    Spring Boot整合web層實現(xiàn)過程詳解

    這篇文章主要介紹了Spring Boot整合web層實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • Java實現(xiàn)打字游戲

    Java實現(xiàn)打字游戲

    這篇文章主要為大家詳細介紹了Java實現(xiàn)打字游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08

最新評論