【MyBatis】深入解析 MyBatis:關于注解和 XML 的 MyBatis 開發方案下字段名不一致的的查詢映射解決方案

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述


注解查詢映射


我們再來調用下面的 selectAll() 這個接口,執行的 SQL 是 select* from user_info,表示全列查詢:
在這里插入圖片描述


運行測試類對應方法,在日志中可以看到,字段名一致,Mybatis 就成功從數據庫對應的字段中拿到值,但是字段名不一樣,則沒有從數據庫中獲取到值;

在這里插入圖片描述

因為 Java 和數據庫的屬性命名規范不同,導致一些字段名稱不同;

雖然數據庫返回的值是正確的,但是并沒有給 Java 中 UserInfo 類對象的各個屬性成功賦值;


此時,我們需要一個轉換規則,讓名稱不一樣的字段可以對應起來:

在這里插入圖片描述


通過 as 起別名映射


我們通過 as 關鍵字來給字段起別名

select id , username, `password`, age, gender, phone, delete_flag as deleteFlag, create_time as createTime, update_time as updateTime from user_info;

驗證 SQL 語句是否可以被成功執行:

在這里插入圖片描述


接下來,我們將起好別名的 SQL 語句用 Mybatis 執行:

在這里插入圖片描述


執行對應測試類方法,觀察打印日志:

在這里插入圖片描述


通過 @Results 進行結構映射映射


但是上面的方式還是比較麻煩的,我們可以通過注解 @Results 來綁定參數:

在這里插入圖片描述


我們再繼續點 Result [ ] 查看源碼:

在這里插入圖片描述


光從源碼,我們還是無法知道 @Results 注解是如何使用的;

下面是 @Results 注解的使用,用于對應名稱不一樣的數據庫字段和 java 屬性:
在這里插入圖片描述


我們重新執行對應的測試類方法,觀察打印日志:

在這里插入圖片描述


通過 @ResultsMap 復用@Results


但是如果后續還要執行關于 select 的 SQL ,豈不是每一個接口方法都要加上:

    @Results({@Result(column = "delete_flag" , property = "deleteFlag"),@Result(column = "create_time" , property = "createTime"),@Result(column = "update_time" , property = "updateTime")})

還是有些麻煩了,是否有更簡單的工具,可以幫我們對應上名稱不一樣的字段呢?

在這里插入圖片描述

我們再來查看 @Results 注解的源碼,源碼不單單只有 Result[ ],還有 id;

這個 id 屬性可以幫我們標識一條 @Result 注解對應的名字:

在這里插入圖片描述


通過上面的方式,我們就給這條注解起好了名字,后續如果還要使用 @Results 映射剛剛的字段,只需要使用 @ResultMap 注解來映射 @Results 即可

在這里插入圖片描述


執行 selectAllById 接口對應的測試類方法,觀察日志,成功給后面三個字段賦值,說明映射成功:
在這里插入圖片描述


開啟駝峰命名


但但但但但是,上面的兩種方式還是太吃操作了,煮啵煮啵,有沒有更簡單快捷的映射方法推薦一下?

有的兄弟,有的!!!

接下來這款操作,不需要修改老長的 SQL 語句,也不需要使用復雜的 @Results、@Result、@ResultMap 注解;

我們只需要賦值下面的代碼到配置文件中,即可實現從數據庫命名規范字段 Java 命名規范字段的轉換:

mybatis:configuration:map-underscore-to-camel-case: true  # 開啟駝峰命名自動轉換

通常數據庫列使用蛇形命名法進行命名(下劃線分割各個單詞),而 Java 屬性一般遵循駝峰命名法約定。

在這里插入圖片描述

為了在這兩種命名方式之間啟用自動映射,需要將mapUnderscoreToCamelCase設置為true。


駝峰命名規則:abc_xyz => abcXyz

  • 表中字段名:abc_xyz
  • 類中屬性名:abcXyz

配置好對應 yml 文件后,我們再來執行下列接口對應的測試類方法:

在這里插入圖片描述


觀察打印日志,賦值成功,說明成功映射參數:

在這里插入圖片描述


XML 查詢映射


通過 as 起別名映射


上文提到,我們可以使用 as 對 SQL 中的字段起別名,來解決查詢映射的問題;

那么在 XML 開發模式下,又該如何解決該問題呢?我們寫出如下 SQL:

select id , username, `password`, age, gender, phone, delete_flag as deleteFlag, create_time as createTime, update_time as updateTime from user_info;

在這里插入圖片描述

值得一提,XML 文件中的 SQL 語句換行沒有意義,依舊代表一個完整的字符串,但是在 java 文件中,SQL 語句換行是需要帶上 + 加號的;


我們執行對應的測試類方法:

在這里插入圖片描述


查看打印日志,可以發現,不同名的對應屬性通過起別名的方式,依舊可以成功映射:

在這里插入圖片描述


結果映射


我們重新添加一個方法,來講解結果映射:

在這里插入圖片描述


<resultsMap>


此時,我們需要使用 <resultMap> </resultMap> 標簽來進行結果映射

在這里插入圖片描述


在這里插入圖片描述


其實<resultsMap>標簽和 @Result 注解源碼是類似的,需要寫的字段一樣,知識寫法不同:

在這里插入圖片描述


@Results 的寫法如下:

在這里插入圖片描述


我們可以類比 <resultsMap> 的寫法:

在這里插入圖片描述


在這里插入圖片描述

不過,如果使用這種方法來映射屬性,就要把對象中的所有屬性的映射都寫全;

因為在別的 XML 文件中,依舊可以引入這個映射,特定場景下,如果這個映射沒有寫入全部對象屬性,則可能會映射不上;


在這里插入圖片描述


在這里插入圖片描述


生成測試語句,調用 selectAll2() 對應的測試類方法,觀察打印日志:

在這里插入圖片描述


開啟駝峰命名


mybatis:configuration:map-underscore-to-camel-case: true  # 開啟駝峰命名自動轉換

在這里插入圖片描述


在這里插入圖片描述

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/74909.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/74909.shtml
英文地址,請注明出處:http://en.pswp.cn/web/74909.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深入理解Java性能調優與JVM底層機制

Java作為一種廣泛應用的編程語言&#xff0c;在企業級應用中占據著舉足輕重的地位。隨著系統規模的擴大和業務需求的復雜化&#xff0c;性能調優成為了開發過程中不可忽視的一環。Java的性能瓶頸往往并不直接來自代碼本身&#xff0c;而是與JVM&#xff08;Java虛擬機&#xff…

odo18實施——銷售-倉庫-采購-制造-制造外包-整個流程自動化單據功能的演示教程

安裝模塊 安裝銷售 、庫存、采購、制造模塊 2.開啟外包功能 在進入制造應用點擊 配置—>設置 勾選外包&#xff0c;點擊保存 添加信息 一、添加客戶信息 點擊到銷售應用 點擊訂單—>客戶 點擊新建 創建客戶1&#xff0c;及其他客戶相關信息&#xff0c;點…

Logo語言的在線課程學習

Logo語言在線課程學習的探索 引言 在信息技術快速發展的今天&#xff0c;編程已經成為一門重要的技能。尤其隨著人工智能、數據分析和互聯網技術的普及&#xff0c;各種編程語言層出不窮&#xff0c;其中Logo語言以其獨特的教育意義和學習優勢&#xff0c;逐漸受到學校和教育…

情感語音的“開源先鋒”!網易開源

語音合成技術近年來取得了顯著進步&#xff0c;特別是在語音克隆、語音助手、配音服務和有聲讀物等領域。然而&#xff0c;如何讓合成的語音更具情感&#xff0c;更貼近人類的真實表達&#xff0c;一直是這一領域的重要研究方向。今天&#xff0c;我們將為大家介紹一款由網易有…

攝像頭模塊對焦方式的類型

攝像頭模塊的對焦方式直接影響成像清晰度和使用場景適應性&#xff0c;不同技術各有其優缺點。以下是常見對焦方式及其原理、特點和應用場景的詳細說明&#xff1a; ?1. 固定對焦&#xff08;Fixed Focus&#xff09;? ?原理?&#xff1a;鏡頭固定在特定距離&#xff08;…

使用Vue、Nodejs以及websocket搭建一個簡易聊天室

簡易聊天室 說在前面效果展示websocketwebsocket的由來websocket的特點 vue前端靜態結構效果代碼 點擊切換用戶以及該用戶高亮實現思路效果展示 發送消息功能效果展示 連接服務端 Nodejs服務器端實現步驟代碼 說在前面 在學習計算機網絡的時候&#xff0c;看到了websocket這個…

【免費】2005-2019年各地級市綠色專利申請量數據

2005-2019年各地級市綠色專利申請量數據 1、時間2005-2019年 2、來源&#xff1a;國家知識產權局 3、指標&#xff1a;省份、城市、年份、綠色發明專利申請量、綠色實用新型專利申請量 4、范圍&#xff1a;360地級市 5、指標解釋&#xff1a;綠色專利是指涉及環保、新能源…

架構師面試(二十六):系統拆分

問題 今天我們聊電商系統實際業務場景的問題&#xff0c;考查對業務系統問題的分析能力、解決問題的能力和對系統長期發展的整體規劃能力。 一電商平臺在早期階段業務發展迅速&#xff0c;DAU在 10W&#xff1b;整個電商系統按水平分層架構進行設計&#xff0c;包括【入口網關…

2. Qt界面文件原理

本節主要介紹ui文件如何與窗口關聯&#xff0c;并通過隱式連接方式顯示對話框 本文部分ppt、視頻截圖原鏈接&#xff1a;[萌馬工作室的個人空間-萌馬工作室個人主頁-嗶哩嗶哩視頻] 1 UI文件如何與窗口關聯 1.1 mainwindow.cpp的頭文件ui_mainwindow.h 根據編譯原理的基本規…

雅思大作文寫作——詞伙、簡單句、并列句的使用

詞伙是一些可以表達我們常用觀點的單詞組合,這個組合可能不只是2-3個單詞,也可能是很多單詞組成的一個短句。 一、詞伙使用 1. 不要中譯英 2. 重視詞伙,而非單詞 如何替換表達 1. 如果要替換的是一個名詞,如students,則有下面的一些方法: A. 使用替換詞或者詞組:y…

?算法OJ?滑動窗口最大值【雙端隊列(deque)】Sliding Window Maximum

文章目錄 雙端隊列(deque)詳解基本特性常用操作1. 構造和初始化2. 元素訪問3. 修改操作4. 容量操作 性能特點時間復雜度&#xff1a;空間復雜度&#xff1a; 滑動窗口最大值題目描述方法思路解決代碼 雙端隊列(deque)詳解 雙端隊列(deque&#xff0c;全稱double-ended queue)是…

電機的了解到調試全方面講解

一、什么是電機 電機是一種將電能轉換為機械能的裝置,通常由定子、轉子和電磁場組成。 當電流通過電機的繞組時,產生的磁場會與電機中的磁場相互作用,從而使電機產生旋轉運動。電機廣泛應用于各種機械設備和工業生產中,是現代社會不可或缺的重要設備之一。 常見的電機種…

分布式微服務系統架構第97集:JVM底層原理

加群聯系作者vx&#xff1a;xiaoda0423 倉庫地址&#xff1a;https://webvueblog.github.io/JavaPlusDoc/ https://1024bat.cn/ JVM 內存結構 Java 虛擬機的內存空間分為 5 個部分&#xff1a; 程序計數器 Java 虛擬機棧 本地方法棧 堆 方法區 JDK 1.8 同 JDK 1.7 比&…

制定大運維管理體系的標準、流程、機制、規范

規劃并制定大運維管理體系的標準、流程、機制、規范&#xff0c;對于確保平臺的可用性和穩定性至關重要。這一過程涉及從頂層設計到具體執行的全面考量&#xff0c;需要綜合考慮業務需求、技術架構、團隊能力等多方面因素。以下是一個基本框架&#xff0c;用于指導如何構建有效…

TruPlasma RF 3006 軟件TRUMPF HUETTINGER TRUPLASMA RF 3006 調試監控軟件

TruPlasma RF 3006 軟件TRUMPF HUETTINGER TRUPLASMA RF 3006 調試監控軟件

第16屆藍橋杯單片機模擬試題Ⅱ

試題 代碼 sys.h #ifndef __SYS_H__ #define __SYS_H__#include <STC15F2K60S2.H> //ds1302.c extern unsigned char time[3]; void w_ds1302(); void r_ds1302(); //iic.c float v_adc(unsigned char addr); //sys.c extern float light_v; extern float rb2_v; exte…

清華《數據挖掘算法與應用》FP-Growth算法

【例 8.7】實現FP 樹算法,并對模擬數據集 simpDat挖掘頻繁項集,最小支持度為2,繪制 FP樹并輸出頻繁項集。 運行結果&#xff1a; 聲明&#xff1a;著作權歸作者所有。商業轉載請聯系作者獲得授權&#xff0c;非商業轉載請注明出處。 # -*- coding: utf-8 -*- ""&q…

npm 項目命名規則

以下是 npm 項目命名規則的詳細說明&#xff1a; 一、核心命名規則 必須使用小寫字母 名稱中不能包含大寫字母。原因&#xff1a; 跨平臺兼容性&#xff08;如 Linux 區分大小寫&#xff0c;而 Windows 不區分&#xff09;。避免命令行和 URL 中的大小寫沖突&#xff08;例如包…

Ubertool 的詳細介紹、安裝指南及使用說明

Ubertool&#xff1a;多協議網絡分析與調試平臺 一、Ubertool 簡介 Ubertool 是一款開源的 多協議網絡分析工具&#xff0c;專為物聯網&#xff08;IoT&#xff09;、嵌入式系統和工業自動化領域設計。它支持藍牙、Wi-Fi、LoRa、CAN總線等多種通信協議的實時監控、數據包捕獲…

AI重構農業:從“面朝黃土“到“數字原野“的產業躍遷—讀中共中央 國務院印發《加快建設農業強國規劃(2024-2035年)》

在東北黑土地的萬畝良田上&#xff0c;無人機編隊正在執行精準施肥作業&#xff1b;在山東壽光的智慧大棚里&#xff0c;傳感器網絡實時調控著番茄生長的微環境&#xff1b;在云南的咖啡種植園中&#xff0c;區塊鏈溯源系統記錄著每粒咖啡豆的旅程。這場靜默的農業革命&#xf…