Mybatis查詢返回Map<String,Object>類型的實(shí)現(xiàn)
這篇我們來說一下Mybatis的查詢結(jié)果返回Map類型。
首先我們?cè)谄髽I(yè)開發(fā)中是很少使用到Map返回類型的,很多都是直接返回一個(gè)對(duì)象實(shí)體。尤其是苞米豆出了MP框架之后,XML都是很少寫的。
那么在什么情況下需要使用Map來作為返回的結(jié)果類型呢?
案例:有一個(gè)模塊A和模塊B,A模塊的POM依賴引入了B模塊,A模塊可以直接使用B模塊的實(shí)體,但是B模塊使用不到A模塊的實(shí)體,如果在B模塊POM中引入A模塊的依賴,那么在運(yùn)行時(shí)會(huì)出現(xiàn)依賴循環(huán)錯(cuò)誤,這時(shí)候就需要自己寫SQL來返回Map類型了,因?yàn)榉祷夭涣肆硪粋€(gè)實(shí)體,所以需要定義 Map集合來返回
第一種:返回值為Map<string,Object>類型,但是只能接收一條數(shù)據(jù),數(shù)據(jù)超過一條會(huì)報(bào)錯(cuò)。如下
第二種:List<Map<String,Object>>類型,返回的是一個(gè)集合,可以接收多條數(shù)據(jù)。這種場景用的最多的還是連接查詢。由于在mybatis查詢返回結(jié)果時(shí)如果設(shè)計(jì)到兩個(gè)表,需要在xml中配置association或者collection或者其他多種方式,但都過于麻煩,所以我們可以使用這種方式來接收返回的數(shù)據(jù)。
第三種:Map<String,Map<String,Object>>類型,返回的是一個(gè)KV,DAO層需要添加@MapKey注解,K為注解的值(注解上的值表示數(shù)據(jù)庫某字段,字段必須保證唯一,例如主鍵或唯一索引的字段),V代表查詢出來的數(shù)據(jù)
我們首先演示一下
第一種:Map<String,Object>類型
package com.ywt.springboot.mapper; import java.util.Map; /** * @author pc */ public interface StudentMapper { //查詢所有的學(xué)生 Map<String,Object> findDataToMap(Integer id); }
Mapper.xml
測試一下
第二種List<Map<String,Object>>
單表查詢返回多條數(shù)據(jù):
Mapper層
Mapper.xml
測試一下
多表查詢返回多條數(shù)據(jù):
Mapper:
@MapKey(value = "id") List<Map<String, Object>> queryList();
XML:
<select id="queryList" resultType="java.util.Map"> select s.*, t.t_name, t.t_id from student s left join teacher t on s.id = t.s_id </select>
測試結(jié)果:
<== Columns: id, name, age, phone, address, t_name, t_id
<== Row: 1, 蔡徐坤, 18, 111, 浙江溫州, 李四, 2
<== Row: 1, 蔡徐坤, 18, 111, 浙江溫州, 張三, 1
<== Row: 2, 五一煩, 20, 333, 派出所, 王五, 3
<== Total: 3
[{t_id=2, address=浙江溫州, phone=111, t_name=李四, name=蔡徐坤, id=1, age=18}, {t_id=1, address=浙江溫州, phone=111, t_name=張三, name=蔡徐坤, id=1, age=18}, {t_id=3, address=派出所, phone=333, t_name=王五, name=五一煩, id=2, age=20}]
第三種:Map<String, Map<String,Object> >
Mapper層
Mapper.xml
測試結(jié)果
到此這篇關(guān)于Mybatis查詢返回Map<String,Object>類型的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Mybatis查詢返回Map<String,Object>內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java中的@Conditional條件注解詳細(xì)解析
這篇文章主要介紹了Java中的@Conditional條件注解詳細(xì)解析,@Conditional是Spring4新提供的注解,它的作用是按照一定的條件進(jìn)行判斷,滿足條件給容器注冊(cè)bean,需要的朋友可以參考下2023-11-11springboot3整合knife4j詳細(xì)圖文教程(swagger增強(qiáng))
開發(fā)api提供對(duì)應(yīng)的接口規(guī)范進(jìn)行聯(lián)調(diào)或并行開發(fā),api文檔管理必不可少,常用的Knife4j基于swagger(依賴已經(jīng)compile),可以進(jìn)行管理,下面這篇文章主要給大家介紹了關(guān)于springboot3整合knife4j的相關(guān)資料,需要的朋友可以參考下2024-03-03JAVA中JSONObject對(duì)象和Map對(duì)象之間的相互轉(zhuǎn)換
這篇文章主要介紹了JAVA中JSONObject對(duì)象和Map對(duì)象之間的相互轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01Mybatis傳參為逗號(hào)分隔的字符串情形進(jìn)行in條件查詢方式
這篇文章主要介紹了Mybatis傳參為逗號(hào)分隔的字符串情形進(jìn)行in條件查詢方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01SpringBoot+Vue+JWT的前后端分離登錄認(rèn)證詳細(xì)步驟
這篇文章主要介紹了SpringBoot+Vue+JWT的前后端分離登錄認(rèn)證,其實(shí)創(chuàng)建后端springboot工程也很簡單,本文安裝idea步驟一步步給大家詳細(xì)介紹,需要的朋友可以參考下2021-09-09在SpringBoot項(xiàng)目中解決依賴沖突問題的方法
在SpringBoot項(xiàng)目中,依賴沖突是一個(gè)常見的問題,特別是當(dāng)項(xiàng)目引入多個(gè)第三方庫或框架時(shí),依賴沖突可能導(dǎo)致編譯錯(cuò)誤、運(yùn)行時(shí)異常或不可預(yù)測的行為,本文給大家介紹了如何在SpringBoot項(xiàng)目中解決以來沖突問題的方法,需要的朋友可以參考下2024-01-01詳解FutureTask如何實(shí)現(xiàn)最大等待時(shí)間
這篇文章主要為大家詳細(xì)介紹了如何從源碼中了解FutureTask實(shí)現(xiàn)最大等待時(shí)間的方法,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2023-03-03Mybatis中實(shí)體類屬性與數(shù)據(jù)列表間映射方法介紹
這篇文章主要介紹了Mybatis中實(shí)體類屬性與數(shù)據(jù)列表間映射方法介紹,一共四中方法,供大家參考。2017-10-10