欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis查詢返回Map<String,Object>類型的實(shí)現(xiàn)

 更新時(shí)間:2023年07月24日 10:18:58   作者:保加利亞的風(fēng)  
本文主要介紹了Mybatis查詢返回Map<String,Object>類型的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

這篇我們來說一下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ì)解析

    這篇文章主要介紹了Java中的@Conditional條件注解詳細(xì)解析,@Conditional是Spring4新提供的注解,它的作用是按照一定的條件進(jìn)行判斷,滿足條件給容器注冊(cè)bean,需要的朋友可以參考下
    2023-11-11
  • Java中如何正確重寫equals方法

    Java中如何正確重寫equals方法

    Object類中equals方法比較的是兩個(gè)對(duì)象的引用地址,只有對(duì)象的引用地址指向同一個(gè)地址時(shí),才認(rèn)為這兩個(gè)地址是相等的,否則這兩個(gè)對(duì)象就不相等
    2021-10-10
  • Java8 List集合如何移除滿足條件的元素

    Java8 List集合如何移除滿足條件的元素

    這篇文章主要介紹了Java8 List集合如何移除滿足條件的元素,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • springboot3整合knife4j詳細(xì)圖文教程(swagger增強(qiáng))

    springboot3整合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-03
  • JAVA中JSONObject對(duì)象和Map對(duì)象之間的相互轉(zhuǎn)換

    JAVA中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-01
  • Mybatis傳參為逗號(hào)分隔的字符串情形進(jìn)行in條件查詢方式

    Mybatis傳參為逗號(hào)分隔的字符串情形進(jìn)行in條件查詢方式

    這篇文章主要介紹了Mybatis傳參為逗號(hào)分隔的字符串情形進(jìn)行in條件查詢方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • SpringBoot+Vue+JWT的前后端分離登錄認(rèn)證詳細(xì)步驟

    SpringBoot+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)目中解決依賴沖突問題的方法

    在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í)間

    詳解FutureTask如何實(shí)現(xiàn)最大等待時(shí)間

    這篇文章主要為大家詳細(xì)介紹了如何從源碼中了解FutureTask實(shí)現(xiàn)最大等待時(shí)間的方法,文中的示例代碼講解詳細(xì),感興趣的可以了解一下
    2023-03-03
  • Mybatis中實(shí)體類屬性與數(shù)據(jù)列表間映射方法介紹

    Mybatis中實(shí)體類屬性與數(shù)據(jù)列表間映射方法介紹

    這篇文章主要介紹了Mybatis中實(shí)體類屬性與數(shù)據(jù)列表間映射方法介紹,一共四中方法,供大家參考。
    2017-10-10

最新評(píng)論