亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

這篇我們來說一下Mybatis的查詢結(jié)果返回Map類型。

首先我們在企業(yè)開發(fā)中是很少使用到Map返回類型的,很多都是直接返回一個對象實體。尤其是苞米豆出了MP框架之后,XML都是很少寫的。

那么在什么情況下需要使用Map來作為返回的結(jié)果類型呢?

案例:有一個模塊A和模塊B,A模塊的POM依賴引入了B模塊,A模塊可以直接使用B模塊的實體,但是B模塊使用不到A模塊的實體,如果在B模塊POM中引入A模塊的依賴,那么在運行時會出現(xiàn)依賴循環(huán)錯誤,這時候就需要自己寫SQL來返回Map類型了,因為返回不了另一個實體,所以需要定義 Map集合來返回

第一種:返回值為Map<string,Object>類型,但是只能接收一條數(shù)據(jù),數(shù)據(jù)超過一條會報錯。如下

第二種:List<Map<String,Object>>類型,返回的是一個集合,可以接收多條數(shù)據(jù)。這種場景用的最多的還是連接查詢。由于在mybatis查詢返回結(jié)果時如果設計到兩個表,需要在xml中配置association或者collection或者其他多種方式,但都過于麻煩,所以我們可以使用這種方式來接收返回的數(shù)據(jù)。

第三種:Map<String,Map<String,Object>>類型,返回的是一個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 {
    //查詢所有的學生
    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>類型的實現(xiàn)的文章就介紹到這了,更多相關(guān)Mybatis查詢返回Map<String,Object>內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • Java中的@Conditional條件注解詳細解析

    Java中的@Conditional條件注解詳細解析

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

    Java中如何正確重寫equals方法

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

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

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

    springboot3整合knife4j詳細圖文教程(swagger增強)

    開發(fā)api提供對應的接口規(guī)范進行聯(lián)調(diào)或并行開發(fā),api文檔管理必不可少,常用的Knife4j基于swagger(依賴已經(jīng)compile),可以進行管理,下面這篇文章主要給大家介紹了關(guān)于springboot3整合knife4j的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • JAVA中JSONObject對象和Map對象之間的相互轉(zhuǎn)換

    JAVA中JSONObject對象和Map對象之間的相互轉(zhuǎn)換

    這篇文章主要介紹了JAVA中JSONObject對象和Map對象之間的相互轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • Mybatis傳參為逗號分隔的字符串情形進行in條件查詢方式

    Mybatis傳參為逗號分隔的字符串情形進行in條件查詢方式

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

    SpringBoot+Vue+JWT的前后端分離登錄認證詳細步驟

    這篇文章主要介紹了SpringBoot+Vue+JWT的前后端分離登錄認證,其實創(chuàng)建后端springboot工程也很簡單,本文安裝idea步驟一步步給大家詳細介紹,需要的朋友可以參考下
    2021-09-09
  • 在SpringBoot項目中解決依賴沖突問題的方法

    在SpringBoot項目中解決依賴沖突問題的方法

    在SpringBoot項目中,依賴沖突是一個常見的問題,特別是當項目引入多個第三方庫或框架時,依賴沖突可能導致編譯錯誤、運行時異常或不可預測的行為,本文給大家介紹了如何在SpringBoot項目中解決以來沖突問題的方法,需要的朋友可以參考下
    2024-01-01
  • 詳解FutureTask如何實現(xiàn)最大等待時間

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

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

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

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

最新評論