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

mybatis的mapper.xml中resultMap標(biāo)簽的使用詳解

 更新時間:2020年06月16日 11:22:44   作者:csdnzoutao  
這篇文章主要介紹了mybatis的mapper.xml中resultMap標(biāo)簽的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

1.前言

  最近博主在做一個ssm框架的共享汽車管理系統(tǒng),其中,數(shù)據(jù)庫字段設(shè)計的有下劃線方式,a_username,然后在寫mapper.xml里面的sql語句的時候,一直出現(xiàn)查詢語句查詢的值為null的情況?;蛘呤莚esultMap標(biāo)簽和駝峰規(guī)則不太明白的同學(xué),可以看這里。

于是順便梳理一下。

2.關(guān)于resultMap

2.1.什么是resultMap?

  在mybatis中有一個resultMap標(biāo)簽,它是為了映射select查詢出來結(jié)果的集合,其主要作用是將實體類中的字段與數(shù)據(jù)庫表中的字段進(jìn)行關(guān)聯(lián)映射。

注意

當(dāng)實體類中的字段與數(shù)據(jù)庫表中的字段相同時,可以將resultMap標(biāo)簽中的關(guān)聯(lián)關(guān)系忽略不寫。
當(dāng)實體類中的字段與數(shù)據(jù)庫表中的字段不相同時,就需要在resultMap標(biāo)簽中將實體類字段與數(shù)據(jù)庫字段一 一進(jìn)行關(guān)聯(lián)映射,或者開啟駝峰規(guī)則,讓它自動轉(zhuǎn)換。

3.舉例說明

3.1.數(shù)據(jù)庫與實體類之間名稱相同

數(shù)據(jù)庫這么寫:

 

然后對應(yīng)寫的實體類:

在mapper中的查詢方式:

可以看到,是最常規(guī)的sql查詢寫法,這樣就能正常的查詢到數(shù)據(jù)庫的數(shù)據(jù)。

當(dāng)然這個時候開不開啟駝峰規(guī)則都可以,比如在mybatis的配置文件中聲明開啟,也是一樣的效果。

這是為什么呢?
順便說幾個關(guān)于實體類、數(shù)據(jù)庫、json格式的知識。

數(shù)據(jù)庫字段、索引對大小寫是不敏感的,駝峰標(biāo)識無意義;也就是你開不開啟實際上都一樣。

json 的規(guī)范格式是帶有下劃線的;比如:

{“id”:”1234” 
“user_name”:”Lilan”;}

數(shù)據(jù)庫字段和 bean 之間字段轉(zhuǎn)換,主流 orm 工具都有映射轉(zhuǎn)換支持,比如上圖mybatis中開啟的駝峰規(guī)則;

json 和 bean 之間字段轉(zhuǎn)換,可以使用注解 @JsonProperty,比如寫實體類的時候:@JsonProperty("user_name")
private String userName;

3.2.數(shù)據(jù)庫與實體類之間不相同

比如常見的寫法: 數(shù)據(jù)庫使用下劃線,與之映射的實體類中采用駝峰原則。
兩種處理方式:

第一種:開啟駝峰規(guī)則

數(shù)據(jù)庫如下:

 

實體類如下:

解決:

在mybatis的配置文件里加入如上的配置,就基本不用property進(jìn)行字段和實體和屬性的映射
在進(jìn)行sql查詢和初始化實體時mybatis會為我們自動轉(zhuǎn)化,寫sql語句的時候也不必為有下劃線的字段設(shè)置與實體類相同的別名。
如未加配置之前的sql查詢語句為(使用別名):
select id, user_name as userName, user_sex as userSex, user_age as userAge from user
加入配置之后的sql語句為(直接使用數(shù)據(jù)庫字段名):
select id, user_name, user_sex, user_age from user

Sql如下:

這樣就能直接查詢出數(shù)據(jù)庫里面的數(shù)據(jù)。

第二種:使用resultMap標(biāo)簽來映射

比如數(shù)據(jù)庫:

實體類如下:

然后在mapper.xml中書寫resultMap標(biāo)簽,使得數(shù)據(jù)庫字段和實體類
名稱映射。(將實體類字段與數(shù)據(jù)庫字段在標(biāo)簽中進(jìn)行一一映射)

源碼如下:

 <!-- type指向javabean類,id可自定義 -->
  <resultMap id="BaseResultMap" type="com.zout.entity.Admin" >
    <id column="aid" property="aid" jdbcType="INTEGER" />
    <!-- property對應(yīng)實體類的屬性名稱,column為數(shù)據(jù)庫字段名 -->
    <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的配置文件中查看是否已經(jīng)去掉駝峰規(guī)則的聲明。使用resultMap,就要禁用駝峰規(guī)則。如果不想改實體類的話,建議采用resultMap。

如圖:

然后sql如下:

這樣就能獲取到對應(yīng)的數(shù)據(jù)。sql語句書寫的時候也可以直接采用數(shù)據(jù)庫字段名。

4.總結(jié)

第一點:

1.mybatis配置文件設(shè)置了這項后,查詢出來的字段如果帶下劃線,那么就會去掉下劃線,
然后采用java駝峰規(guī)則。

比如數(shù)據(jù)庫字段Parent_id,那么查詢出來后,會轉(zhuǎn)為parentid,然后去實體類Category匹配對應(yīng)的字段。 這個時候?qū)嶓w類里就不能寫有下劃線,不然就匹配不上。會出現(xiàn)查詢結(jié)果都是null值。

第二點:

1.當(dāng)進(jìn)行單表簡單查詢時且返回值類型是基本類型時,一般mapper的返回類型盡量使用resultType=”xxxx”;

2.當(dāng)進(jìn)行多表關(guān)聯(lián)查詢時,或者說xml中定義了相關(guān)的resultMap標(biāo)簽,那么就一般盡量使用resultMap=”xxxx”;

3.在mapper.xml當(dāng)中,resultType和resultMap是不能同時使用。

第三點:

關(guān)于數(shù)據(jù)庫字段和實體類名稱不相同的時候,要么采用resultMap標(biāo)簽, 要么啟用駝峰規(guī)則,但是兩者不能同時使用。

到此這篇關(guān)于mybatis的mapper.xml中resultMap標(biāo)簽的使用詳解的文章就介紹到這了,更多相關(guān)mybatis resultMap標(biāo)簽使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用Java代碼實現(xiàn)Redis和數(shù)據(jù)庫數(shù)據(jù)同步

    使用Java代碼實現(xiàn)Redis和數(shù)據(jù)庫數(shù)據(jù)同步

    這篇文章主要介紹了使用Java代碼實現(xiàn)Redis和數(shù)據(jù)庫數(shù)據(jù)同步問題,文中通過代碼示例給大家講解的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-06-06
  • 如何在Java SpringBoot項目中配置動態(tài)數(shù)據(jù)源你知道嗎

    如何在Java SpringBoot項目中配置動態(tài)數(shù)據(jù)源你知道嗎

    這篇文章主要介紹了SpringBoot如何在運行時動態(tài)添加數(shù)據(jù)源,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2021-09-09
  • java 使用異常的好處總結(jié)

    java 使用異常的好處總結(jié)

    這篇文章主要介紹了java 使用異常的好處總結(jié)的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • 32位和64位皆適用的MyEclipse安裝教程

    32位和64位皆適用的MyEclipse安裝教程

    這篇文章主要為大家詳細(xì)介紹了32位和64位皆適用的MyEclipse安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • MyBatis 自動更新時間的方法實現(xiàn)

    MyBatis 自動更新時間的方法實現(xiàn)

    本文主要介紹了MyBatis 自動更新時間的方法實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • SpringBoot加載bean的八種方式總結(jié)

    SpringBoot加載bean的八種方式總結(jié)

    springboot難免要用到bean,但這些bean如何導(dǎo)入,對于初學(xué)者時間頭疼的事,下面這篇文章主要給大家介紹了關(guān)于SpringBoot加載bean的八種方式,需要的朋友可以參考下
    2022-10-10
  • 完美解決idea沒有tomcat server選項的問題

    完美解決idea沒有tomcat server選項的問題

    這篇文章主要介紹了完美解決idea沒有tomcat server選項的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Java的編譯時錯誤和運行時錯誤問題

    Java的編譯時錯誤和運行時錯誤問題

    這篇文章主要介紹了Java的編譯時錯誤和運行時錯誤問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 基于springboot攔截器HandlerInterceptor的注入問題

    基于springboot攔截器HandlerInterceptor的注入問題

    這篇文章主要介紹了springboot攔截器HandlerInterceptor的注入問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • 淺談java socket的正確關(guān)閉姿勢

    淺談java socket的正確關(guān)閉姿勢

    這篇文章主要介紹了java socket的正確關(guān)閉姿勢,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06

最新評論