日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:316日期:2023-10-23 18:28:52

1.前言

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

于是順便梳理一下。

2.關(guān)于resultMap

2.1.什么是resultMap

在mybatis中有一個resultMap標(biāo)簽,它是為了映射select查詢出來結(jié)果的集合,其主要作用是將實體類中的字段與數(shù)據(jù)庫表中的字段進行關(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ù)庫字段一 一進行關(guān)聯(lián)映射,或者開啟駝峰規(guī)則,讓它自動轉(zhuǎn)換。

3.舉例說明

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

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

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

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

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

在mapper中的查詢方式:

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

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

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

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

這是為什么呢? 順便說幾個關(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的mapper.xml中resultMap標(biāo)簽的使用詳解

實體類如下:

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

解決:

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

在mybatis的配置文件里加入如上的配置,就基本不用property進行字段和實體和屬性的映射 在進行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如下:

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

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

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

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

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

實體類如下:

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

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

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

源碼如下:

<!-- type指向javabean類,id可自定義 --> <resultMap 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。

如圖:

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

然后sql如下:

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

這樣就能獲取到對應(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)進行單表簡單查詢時且返回值類型是基本類型時,一般mapper的返回類型盡量使用resultType=”xxxx”;

2.當(dāng)進行多表關(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)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Mybatis 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
美女网站一区| 亚洲一本视频| 亚洲欧美在线专区| 鲁大师影院一区二区三区| 91精品1区| 黑丝一区二区| 少妇久久久久| 久久久久免费av| 久久久久国产一区二区| 日韩欧美少妇| 激情综合自拍| 国产日韩综合| 蜜桃av一区二区| 日韩激情一区二区| 欧美片网站免费| 久久伊人国产| 久久久久免费av| 中文一区在线| 日本精品另类| 麻豆成人av在线| 91日韩在线| 日本一区二区高清不卡| 亚洲综合在线电影| 激情久久婷婷| 亚洲精品女人| 国产极品嫩模在线观看91精品| 黄色精品视频| 久久精品91| 亚洲精品婷婷| 精品视频国产| 国产一区日韩欧美| 一区二区国产精品| 欧美1区2区3| 久久久久国产精品一区二区| 日韩中文字幕1| 国产精品一卡| 日韩欧美一区二区三区在线视频| 欧美在线网站| 亚洲精品在线国产| 九九久久国产| 在线亚洲欧美| 麻豆成人91精品二区三区| 日韩理论片av| 日韩美女精品| 中文在线中文资源| 亚洲欧洲国产精品一区| 久久精品国产在热久久| 九九综合九九| 国产探花一区二区| www成人在线视频| 日韩手机在线| 中文字幕在线官网| 爽好久久久欧美精品| 久久影院一区二区三区| 亚洲黄页一区| 欧美激情网址| 午夜在线一区| 色欧美自拍视频| 亚洲欧美久久| 精品国产亚洲一区二区在线观看| 亚洲一区二区毛片| 国产在线一区不卡| 在线精品视频一区| 欧美三级精品| 国产无遮挡裸体免费久久| 亚洲第一精品影视| 国产亚洲第一伦理第一区| 欧美成a人免费观看久久| 欧美日一区二区在线观看| 激情欧美一区二区三区| 美女av一区| 日韩免费精品| 欧美特黄一区| 国产一区二区三区不卡视频网站| 久久最新视频| 日韩在线观看| 久久免费精品| 日韩精品一区二区三区中文字幕| 欧美亚洲激情| 国内精品麻豆美女在线播放视频| 亚洲免费福利一区| 91精品1区| 欧美aa在线观看| 欧美精品导航| 日本亚洲欧洲无免费码在线| 欧洲激情综合| 91精品韩国| 国内自拍视频一区二区三区| 日本91福利区| 日韩专区欧美专区| 亚洲大片在线| 国产v综合v| 92国产精品| 久久伊人久久| 国产欧美自拍| 日韩在线观看中文字幕| 九九综合在线| 神马日本精品| 精品五月天堂| 国产精品综合| 日本欧美在线| 亚洲精品麻豆| 亚洲一区亚洲| 红桃视频国产一区| 亚洲成人二区| 久久精品高清| 国产99精品一区| 91看片一区| 精品日韩视频| 欧美13videosex性极品| 国产精品13p| 精品久久视频| 麻豆精品视频在线| 久久超级碰碰| 欧美a级一区二区| 美女av一区| 久久影院一区二区三区| 国产精品a级| 麻豆久久一区| 成人在线超碰| 成人午夜在线| 一区二区精品伦理...| 国产成人黄色| 9999国产精品| 涩涩av在线| 成人日韩在线观看| 99久久精品国产亚洲精品| 欧美成人基地 | 亚洲字幕久久| 美国三级日本三级久久99 | 国产免费成人| 亚洲一级影院| 欧美福利专区| 日韩午夜精品| 亚洲小说春色综合另类电影| 日韩区欧美区| 久久不见久久见中文字幕免费| 久久伊人久久| 日韩中文字幕高清在线观看| 久久精品国产亚洲夜色av网站| 欧美在线观看视频一区| 视频精品一区二区| 日本不卡视频在线观看| 国产精品xxxav免费视频| 老牛国内精品亚洲成av人片| 国产一区二区三区国产精品| 在线天堂中文资源最新版| 999国产精品| 国产精品嫩草99av在线| 亚洲深深色噜噜狠狠爱网站| 国产午夜久久av| 福利一区二区免费视频| 欧美色图国产精品| 亚洲小说春色综合另类电影| 国产探花在线精品| 日韩欧美一区二区三区在线视频 | 免费看欧美美女黄的网站| 中文不卡在线| 国产精品扒开腿做爽爽爽软件| 蜜臀国产一区| 久久99伊人| 国产伦一区二区三区| 国产精品国产一区| 欧美二区视频| 日韩国产高清在线| 国产精品精品| 丝袜脚交一区二区| 国产精久久一区二区| 欧美亚洲精品在线| 天堂俺去俺来也www久久婷婷| 久久精品天堂| 好吊日精品视频| 日韩av电影一区| 日韩1区2区| 视频一区二区三区入口| 欧美精品aa| 91久久久精品国产| 国产毛片久久久| 婷婷亚洲五月| 国产亚洲电影| 亚洲欧美不卡| 激情不卡一区二区三区视频在线| 午夜日韩在线| 久久99影视| 日韩在线一二三区| 欧美激情另类| 日韩精品三级| 亚洲风情在线资源| 亚洲精品极品| 日韩欧美综合| 国产一区 二区| 一区二区自拍| 国产suv精品一区二区四区视频| 久久国产成人| av最新在线| 欧美日韩亚洲一区| 亚洲精品1区| 成午夜精品一区二区三区软件| 亚州精品视频| 国产二区精品|