mybatis進階--一對多查詢

来源:http://www.cnblogs.com/liyasong/archive/2017/02/17/mybatis_yddcx.html
-Advertisement-
Play Games

一對多查詢,其實就是使用resultMap的collection對關聯查詢的多條記錄映射到一個list集合屬性中,如果一對一中的resultMap方式使用的比較6的話,可以不看的東西。如果不會搞的小伙伴,可以來這裡看看,還是比較詳細的。 ...


  首先,我們還是先給出一個需求:根據訂單id查詢訂單明細——我們知道,一個訂單裡面可以有多個訂單的明細(需求不明確的同學,請留言或者去淘寶網上的訂單處點一下就知道了)。這個時候,一個訂單,對應多個訂單的id。這種需求出現的時候,我們應該如何查詢呢?

  此時我們的數據模型如下圖(左)由於查詢用戶也是我們的需求,所以就在原有的基礎上進行擴展,數據模型如下(右):

 

    很顯然,如果用resultType的方式去實現的話,是不合理的了。因為我們需要創建一個既有訂單又有訂單明細的pojo然後呢,我們的mybatis框架會為我們映射出很多個pojo對象(有多少個訂單明細就有多少個對象)。

    所以我們需要使用resultMap的方式進行處理。解決問題的思路是:在orders類中增加一個訂單明細的List欄位將list的類型定義為Orderdetail類型。然後通過配置文件,將得到的數據,通過resultMap的collection標簽進行映射到list中。

    具體實現如下:

  sql語句

    確定主查詢表:訂單表

    確定關聯查詢表:訂單明細表

    在一對一查詢基礎上添加訂單明細表關聯即可。

    

 1 SELECT 
 2   orders.*,
 3   USER.username,
 4   USER.sex,
 5   USER.address,
 6   orderdetail.id orderdetail_id,
 7   orderdetail.items_id,
 8   orderdetail.items_num,
 9   orderdetail.orders_id
10 FROM
11   orders,
12   USER,
13   orderdetail
14 WHERE orders.user_id = user.id AND orderdetail.orders_id=orders.id

 

  問題展示

    查詢完畢以後,我們發現了一個問題:如圖所示,我們的id出現了多條,這是因為資料庫中對應的多個訂單詳情共同使用一個訂單id導致的。這就導致了每條記錄中都會出現一個orders的記錄。具體解決辦法,開始的時候就說了,這裡就不再贅述了。

    

  在orders中添加list訂單明細屬性

    

 

    定義resultMap

 1 <!-- 訂單及訂單明細的resultMap
 2     使用extends繼承,不用再重覆用戶的映射
 3      -->
 4     <resultMap type="cn.itcast.mybatis.po.Orders" id="dinxtends="OrdersUserResultMap">
 5         <!-- 訂單信息 -->
 6         <!-- 用戶信息 -->
 7         <!-- 使用extends繼承,不用在中配置訂單信息和用戶信息的映射 -->
 8         
 9         
10         <!-- 訂單明細信息
11         一個訂單關聯查詢出了多條明細,要使用collection進行映射
12         collection:對關聯查詢到多條記錄映射到集合對象中
13         property:將關聯查詢到多條記錄映射到cn.itcast.mybatis.po.Orders哪個屬性
14         ofType:指定映射到list集合屬性中pojo的類型
15          -->
16          <collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail">
17              <!-- id:訂單明細唯 一標識
18              property:要將訂單明細的唯 一標識 映射到cn.itcast.mybatis.po.Orderdetail的哪個屬性
19                -->
20              <id column="orderdetail_id" property="id"/>
21              <result column="items_id" property="itemsId"/>
22              <result column="items_num" property="itemsNum"/>
23              <result column="orders_id" property="ordersId"/>
24          </collection>
25         
26     
27     </resultMap>

    statement定義

    

  mapper

    

  總結

    其實就是使用resultMap的collection對關聯查詢的多條記錄映射到一個list集合屬性中。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在使用“PHPWAMP自動任務”時,不少學生遇到如下問題: “phpwamp綠色集成環境重啟動電腦(伺服器)後,不會自動啟動網站服務” (如果是其他環境或是自己搭建時遇到此問題,也是可以用此法解決) 此文章內容符合: 為什麼網站服務由手動變成自動後還是無法重啟? 為什麼我把服務設置成自動後,開機又變 ...
  • 本文地址 分享提綱: 1.概述 2.安裝 3.編寫第一個測試用例 4.PHPUnit高級 5.參考 分享提綱: 1.概述 2.安裝 3.編寫第一個測試用例 4.PHPUnit高級 5.參考 1.概述 1)【測試框架】 它是一款輕量級的PHP測試框架,是一個xUnit的體繫結構的單元測試框架。複雜的項 ...
  • 本試題共40道選擇題,10道判斷題,考試時間1個半小時 一:選擇題(單項選擇,每題2分): 1. LAMP具體結構不包含下麵哪種(A ) A:Windows系統 B:Apache伺服器 C:MySQL資料庫 D:PHP語言 2. 以下哪個SQL語句是正確的(D) A:insert into user ...
  • 1. LAMP具體結構不包含下麵哪種(A ) A:Windows系統 如果是這個就是WMP B:Apache伺服器 C:MySQL資料庫 D:PHP語言 2. 以下哪個SQL語句是正確的(D ) A:insert into users 少了一個values (‘p001’,’張三’,’男’); B: ...
  • 轉載請標明出處: "http://www.cnblogs.com/why168888/p/6407980.html" 本文出自: "【Edwin博客園】" Python迭代 1. 什麼是迭代 註意: 集合是指包含一組元素的數據結構,我們已經介紹的包括: 1. 有序集合:list,tuple,str和 ...
  • 安全問題已經成為一個越來越重要的問題,在Java中如何對重要數據進行加密解密是本文的主要內容。 一、常用的加密/解密演算法 1.Base64 嚴格來說Base64並不是一種加密/解密演算法,而是一種編碼方式。Base64不生成密鑰,通過Base64編碼後的密文就可以直接“翻譯”為明文,但是可以通過向明文 ...
  • 一、myeclipse之web項目的部署(發佈)流程 web項目的部署(發佈)流程2008-01-18 14:35 在myeclipse下新建web工程abc。系統設置預設如下: 項目保存位置:workspace目錄\abc Source文件夾:src,保存所有的Java類文件(.java文件)和x ...
  • 題目大意: 給出一棵樹,每條邊有權值,求經過少於l條邊,權值和少於w的路徑總數。 點分治。每次求出所有點到重心的距離,按w排序,然後維護一個樹狀數組,記錄經過的邊<=i的點個數。由於可能兩個點都在一棵子樹中,再容斥一下就好了。 代碼: 1 #include<iostream> 2 #include< ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...