电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

mybatis的mapper.xml中resultMap標簽的使用詳解

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

1.前言

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

于是順便梳理一下。

2.關于resultMap

2.1.什么是resultMap

在mybatis中有一個resultMap標簽,它是為了映射select查詢出來結果的集合,其主要作用是將實體類中的字段與數據庫表中的字段進行關聯映射。

注意

當實體類中的字段與數據庫表中的字段相同時,可以將resultMap標簽中的關聯關系忽略不寫。 當實體類中的字段與數據庫表中的字段不相同時,就需要在resultMap標簽中將實體類字段與數據庫字段一 一進行關聯映射,或者開啟駝峰規則,讓它自動轉換。

3.舉例說明

3.1.數據庫與實體類之間名稱相同

數據庫這么寫:

mybatis的mapper.xml中resultMap標簽的使用詳解 

然后對應寫的實體類:

mybatis的mapper.xml中resultMap標簽的使用詳解

在mapper中的查詢方式:

mybatis的mapper.xml中resultMap標簽的使用詳解

可以看到,是最常規的sql查詢寫法,這樣就能正常的查詢到數據庫的數據。

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

mybatis的mapper.xml中resultMap標簽的使用詳解

這是為什么呢? 順便說幾個關于實體類、數據庫、json格式的知識。

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

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

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

數據庫字段和 bean 之間字段轉換,主流 orm 工具都有映射轉換支持,比如上圖mybatis中開啟的駝峰規則;

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

3.2.數據庫與實體類之間不相同

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

第一種:開啟駝峰規則

數據庫如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

實體類如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

解決:

mybatis的mapper.xml中resultMap標簽的使用詳解

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

Sql如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

這樣就能直接查詢出數據庫里面的數據。

第二種:使用resultMap標簽來映射

比如數據庫:

mybatis的mapper.xml中resultMap標簽的使用詳解

實體類如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

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

mybatis的mapper.xml中resultMap標簽的使用詳解

源碼如下:

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

如圖:

mybatis的mapper.xml中resultMap標簽的使用詳解

然后sql如下:

mybatis的mapper.xml中resultMap標簽的使用詳解

這樣就能獲取到對應的數據。sql語句書寫的時候也可以直接采用數據庫字段名。

4.總結

第一點:

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

比如數據庫字段Parent_id,那么查詢出來后,會轉為parentid,然后去實體類Category匹配對應的字段。 這個時候實體類里就不能寫有下劃線,不然就匹配不上。會出現查詢結果都是null值。

第二點:

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

2.當進行多表關聯查詢時,或者說xml中定義了相關的resultMap標簽,那么就一般盡量使用resultMap=”xxxx”;

3.在mapper.xml當中,resultType和resultMap是不能同時使用。

第三點:

關于數據庫字段和實體類名稱不相同的時候,要么采用resultMap標簽, 要么啟用駝峰規則,但是兩者不能同時使用。

到此這篇關于mybatis的mapper.xml中resultMap標簽的使用詳解的文章就介紹到這了,更多相關mybatis resultMap標簽使用內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 不锈钢螺丝 - 六角螺丝厂家 - 不锈钢紧固件 - 万千紧固件--紧固件一站式采购 | 亮点云建站-网站建设制作平台 | 专业的压球机生产线及解决方案厂家-河南腾达机械厂 | 礼堂椅厂家|佛山市艺典家具有限公司 | 塑胶跑道_学校塑胶跑道_塑胶球场_运动场材料厂家_中国塑胶跑道十大生产厂家_混合型塑胶跑道_透气型塑胶跑道-广东绿晨体育设施有限公司 | 动物麻醉机-数显脑立体定位仪-北京易则佳科技有限公司 | 偏心半球阀-电动偏心半球阀-调流调压阀-旋球阀-上欧阀门有限公司 | (中山|佛山|江门)环氧地坪漆,停车场地板漆,车库地板漆,聚氨酯地板漆-中山永旺地坪漆厂家 | 安规电容|薄膜电容|陶瓷电容|智旭JEC安规电容厂家 | 脉冲除尘器,除尘器厂家-淄博机械| 预制舱-电力集装箱预制舱-模块化预制舱生产厂家-腾达电器设备 | 成都治疗尖锐湿疣比较好的医院-成都治疗尖锐湿疣那家医院好-成都西南皮肤病医院 | 米顿罗计量泵(科普)——韬铭机械 | 【甲方装饰】合肥工装公司-合肥装修设计公司,专业从事安徽办公室、店面、售楼部、餐饮店、厂房装修设计服务 | 高低温老化试验机-步入式/低温恒温恒湿试验机-百科 | 二手色谱仪器,十万分之一分析天平,蒸发光检测器,电位滴定仪-湖北捷岛科学仪器有限公司 | 房屋质量检测-厂房抗震鉴定-玻璃幕墙检测-房屋安全鉴定机构 | 手机游戏_热门软件app下载_好玩的安卓游戏下载基地-吾爱下载站 | 柔软云母板-硬质-水位计云母片组件-首页-武汉长丰云母绝缘材料有限公司 | 壹车网 | 第一时间提供新车_资讯_报价_图片_排行! | 丽陂特官网_手机信号屏蔽器_Wifi信号干扰器厂家_学校考场工厂会议室屏蔽仪 | 蓝莓施肥机,智能施肥机,自动施肥机,水肥一体化项目,水肥一体机厂家,小型施肥机,圣大节水,滴灌施工方案,山东圣大节水科技有限公司官网17864474793 | 石家庄装修设计_室内家装设计_别墅装饰装修公司-石家庄金舍装饰官网 | 耐腐蚀泵,耐腐蚀真空泵,玻璃钢真空泵-淄博华舜耐腐蚀真空泵有限公司 | 并网柜,汇流箱,电控设备,中高低压开关柜,电气电力成套设备,PLC控制设备订制厂家,江苏昌伟业新能源科技有限公司 | Q361F全焊接球阀,200X减压稳压阀,ZJHP气动单座调节阀-上海戎钛 | 818手游网_提供当下热门APP手游_最新手机游戏下载 | 超高频感应加热设备_高频感应电源厂家_CCD视觉检测设备_振动盘视觉检测设备_深圳雨滴科技-深圳市雨滴科技有限公司 | 恒温恒湿试验箱_高低温试验箱_恒温恒湿箱-东莞市高天试验设备有限公司 | 银川美容培训-美睫美甲培训-彩妆纹绣培训-新娘化妆-学化妆-宁夏倍莱妮职业技能培训学校有限公司 临时厕所租赁_玻璃钢厕所租赁_蹲式|坐式厕所出租-北京慧海通 | 对夹式止回阀_对夹式蝶形止回阀_对夹式软密封止回阀_超薄型止回阀_不锈钢底阀-温州上炬阀门科技有限公司 | 电动卫生级调节阀,电动防爆球阀,电动软密封蝶阀,气动高压球阀,气动对夹蝶阀,气动V型调节球阀-上海川沪阀门有限公司 | 酸度计_PH计_特斯拉计-西安云仪| 考勤系统_考勤管理系统_网络考勤软件_政企|集团|工厂复杂考勤工时统计排班管理系统_天时考勤 | 衬氟止回阀_衬氟闸阀_衬氟三通球阀_衬四氟阀门_衬氟阀门厂-浙江利尔多阀门有限公司 | 油罐车_加油机_加油卷盘_加油机卷盘_罐车人孔盖_各类球阀_海底阀等车用配件厂家-湖北华特专用设备有限公司 | 网站制作优化_网站SEO推广解决方案-无锡首宸信息科技公司 | 数显恒温培养摇床-卧式/台式恒温培养摇床|朗越仪器 | 膏方加工_丸剂贴牌_膏滋代加工_湖北康瑞生物科技有限公司 | 九州网址_专注于提供网址大全分享推广中文网站导航服务 | 成都离婚律师|成都结婚律师|成都离婚财产分割律师|成都律师-成都离婚律师网 |