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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...