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

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

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

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

1.前言

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

于是順便梳理一下。

2.關(guān)于resultMap

2.1.什么是resultMap

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

注意

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

3.舉例說明

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

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

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

然后對(duì)應(yīng)寫的實(shí)體類:

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

在mapper中的查詢方式:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

實(shí)體類如下:

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

解決:

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

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

Sql如下:

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

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

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

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

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

實(shí)體類如下:

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

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

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

源碼如下:

<!-- type指向javabean類,id可自定義 --> <resultMap type='com.zout.entity.Admin' > <id column='aid' property='aid' jdbcType='INTEGER' /> <!-- property對(duì)應(yīng)實(shí)體類的屬性名稱,column為數(shù)據(jù)庫(kù)字段名 --> <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ī)則。如果不想改實(shí)體類的話,建議采用resultMap。

如圖:

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

然后sql如下:

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

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

4.總結(jié)

第一點(diǎn):

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

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

第二點(diǎn):

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

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

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

第三點(diǎn):

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

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

相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
99精品在线| 欧美.日韩.国产.一区.二区 | 中文字幕在线视频网站| 美腿丝袜亚洲三区| 国产精品s色| av中文字幕在线观看第一页 | 国产日韩欧美一区在线| 国产精品1区| 亚洲最新无码中文字幕久久| 国产欧美一区二区精品久久久| 国产精品nxnn| 欧美一级鲁丝片| 国精品一区二区| 亚洲精品人人| 国产精品大片免费观看| 欧美男人天堂| 亚洲少妇一区| 国产亚洲高清在线观看| 免费福利视频一区二区三区| 激情综合网站| 欧美高清一区| 日本va欧美va精品发布| 91视频一区| 伊人影院久久| 日本欧美一区| 91精品国产91久久久久久黑人| 日韩精品一二区| 精品日韩一区| 老司机久久99久久精品播放免费| 国产精品一线天粉嫩av| 999久久久精品国产| 日韩中文av| 日韩高清中文字幕一区| 日韩免费高清| 日韩有码av| 亚洲a在线视频| 欧美一区91| 日韩在线欧美| 欧美日韩调教| 欧美精品一区二区三区精品| 欧美一区激情| 欧美不卡在线| 免费日韩一区二区三区| 国产亚洲高清视频| 国产福利91精品一区二区| 国产视频亚洲| 精品91福利视频| 亚洲欧美日韩国产一区| 国产成人免费精品| 亚洲精品美女91| 欧美日韩在线二区| 欧美黄页在线免费观看| 黑丝一区二区三区| 麻豆精品少妇| 丝袜诱惑制服诱惑色一区在线观看| 欧美激情在线精品一区二区三区| 在线精品一区| 在线日韩一区| 高清久久一区| 91午夜精品| 国产精品美女久久久| 国产成人精品亚洲线观看 | 99精品视频精品精品视频| 亚洲一区日韩| 日韩国产专区| 国产成年精品| 欧美日韩中出| 亚洲三级毛片| 香蕉久久99| 高清一区二区三区av| 国产精品永久| 欧美日韩1区2区3区| 亚洲欧美日本日韩| 免费视频亚洲| 999久久久91| 日韩大片在线| 精品一区电影| 亚洲精品麻豆| 亚洲专区欧美专区| 欧美.日韩.国产.一区.二区| 欧美日韩精品免费观看视完整 | 日本成人手机在线| 欧美不卡在线| 亚洲国产一区二区三区在线播放| 日韩精品网站| 性欧美69xoxoxoxo| 一本一道久久a久久精品蜜桃| 久久国产欧美| 久久国产小视频| 91精品亚洲| 国产精品一区亚洲| 国产精久久一区二区| 免费在线亚洲| 美女久久久久久| 久久99精品久久久久久园产越南 | 蜜桃av一区二区三区电影| 国产在线日韩| 欧美日韩三区| 免费精品视频最新在线| 亚洲免费专区| 国产欧美日韩亚洲一区二区三区| 国产欧美高清视频在线| 国产精品三p一区二区| 麻豆国产欧美一区二区三区| 麻豆极品一区二区三区| 久久女人天堂| 另类专区亚洲| 国产欧洲在线| 国产一区日韩一区| 免费精品视频最新在线| 日本欧美一区二区| 国产精品magnet| 青青青免费在线视频| 亚洲无线一线二线三线区别av| 99国内精品| 欧美日韩国产一区二区在线观看| 日韩美女精品| 国产精品美女在线观看直播| 欧美激情日韩| 久久久久国产精品一区二区| 免费国产自久久久久三四区久久| 亚洲一区欧美激情| 日本不卡高清| 成人黄色av| 欧美日韩中文字幕一区二区三区| 97se综合| 国产aⅴ精品一区二区四区| 日韩不卡一区| 日韩国产激情| 视频一区二区不卡| 国产精品v一区二区三区| 成人亚洲一区| 五月婷婷亚洲| 国产精品一二| 99视频精品视频高清免费| 亚洲专区在线| 美女精品一区二区| 精品国产18久久久久久二百| 999久久久免费精品国产| 中文字幕亚洲影视| 精品三级av在线导航| 九九综合九九| 婷婷五月色综合香五月| 国产+成+人+亚洲欧洲在线| 亚洲一区久久| 免费一级欧美在线观看视频 | 日本一区福利在线| 98精品久久久久久久| 亚洲深爱激情| 国产日产精品一区二区三区四区的观看方式| 91视频精品| 日韩国产在线不卡视频| 日韩电影二区| 久久精品97| 欧美成人综合| 日本午夜精品一区二区三区电影| 日韩欧美三级| 日本电影久久久| 九一国产精品| 久久精品国产网站| 久久亚洲视频| 三级在线看中文字幕完整版| 99热精品在线观看| 精品日韩一区| 首页亚洲欧美制服丝腿| 福利视频一区| 欧美日本久久| 黄色精品网站| 国产一区二区三区亚洲| 久久国产精品亚洲77777| 手机在线电影一区| 日韩av资源网| 亚洲综合日本| 国产麻豆久久| 精品黄色一级片| 日韩久久99| 香蕉视频成人在线观看| 三级欧美韩日大片在线看| 亚洲色图综合| 99视频精品全国免费| 亚洲免费观看| 日韩一区电影| 久久一区视频| 日韩**一区毛片| 鲁大师影院一区二区三区| 欧产日产国产精品视频| 国产精品videossex久久发布| 日韩中文字幕在线一区| 日韩亚洲在线| 深夜视频一区二区| 美女国产一区二区三区| 欧美一区91| 日韩精品久久理论片| 三级在线观看一区二区| 黄色av日韩| 91超碰国产精品| 蜜桃一区二区三区| 午夜国产精品视频| 黄页网站一区| 国产精品美女久久久浪潮软件|