mybatis進階--一對一查詢

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

mybatis 一對一查詢的兩種方式的實現,較為詳細。歡迎新手學習及大神指導。 ...


   所謂的一對一查詢,就是說我們在查詢一個表的數據的時候,需要關聯查詢其他表的數據。

 需求

    首先說一個使用一對一查詢的小需求吧:假設我們在查詢某一個訂單的信息的時候,需要關聯查詢出創建這個訂單對應的用戶信息。表模型如下(

    

 ResultType

  sql語句的書寫

    首先,我們要對我們的需求進行分析。1.我們需要確定這個需求需要涉及到哪兩張表,其中哪個是主表,哪個是關聯表。具體怎麼確定,還是看需求——我們的需求是說,在查詢訂單的時候,順帶著查出創建這個訂單的用戶。那麼,已經很顯然了。我們的主表是訂單表(orders)。而我們的關聯表則是用戶表(user)。

    這個時候,我們就可以寫出來如下sql語句了:

    select * from orders

    這個時候,我們就應該考慮這個問題了:我們在關聯查詢的時候應該使用內鏈接?還是外鏈接?對於搞不清內鏈接外鏈接的區別的同學,我這裡先簡單的介紹一下,等以後有時間了,再詳細寫一篇博客說明:內連接是只顯示滿足條件的。外鏈接分為左外和右外鏈接:左連接顯示左邊全部的再加上右邊與左邊相同的;右連接顯示右邊全部的和左邊與右邊相同的。

  我們的需求是通過訂單去關聯用戶,而由於在orders表中有一個外鍵(userId)。通過外鍵的去查關聯表user表的數據時,userId是user表的主鍵。這時,只能查到一條user的信息,而這條記錄不會導致我們的主查詢結果發生改變。所以,我們選擇內鏈接查詢。這時候,我們的sql語句是這樣的:

  select * from orders,user where orders.user_id = user.id

    查詢完成後,出現結果如下:

    

    這時,問題來了,我們發現,這個時候出現了兩個id,這就會導致我們的數據在輸出的時候封裝到對象時會出現問題。而且,User_id 這一列和我們的用戶id數據是重覆的。我們需要改造我們的sql。怎麼改造呢?

    因為我們的主表數據是要全部查詢的,而用戶表我們只需要username,sex,adress這三個信息(這裡是假設,沒必要糾結需要的是啥信息)。那麼我們就需要手動指定我們的sql語句的查詢欄位了:

    
1 SELECT 
2   orders.*,
3   USER.username,
4   USER.sex,
5   USER.address 
6 FROM
7   orders,
8   USER 
9 WHERE orders.user_id = user.id
最終的sql語句

    前面的這些都是在我們的sql鏈接工具上進行查詢的,當可以顯示我們需要的資料庫後,我們的sql語句就確定了。這時我們該開始下一步了:

   創建pojo

    我們需要將查詢到的結果,通過mybatis框架將數據封裝到對應的對象。那麼,問題來了,這個查詢到的數據由誰來接收?我們如果要將上邊sql查詢的結果映射到pojo中,pojo中必須包括所有查詢列名。但是不管是原來的Orders類還是User類,都沒有辦法映射全部的欄位。這時,我們有一個很簡單的解決辦法:根據返回的欄位,專門寫一個類,讓它包含所有的查詢結果,然後讓這個類去接收這個返回的結果集。

    這時有個小技巧,我們的新的pojo中,不需要將所有的欄位全部都寫上,我們可以讓新pojo去繼承我們的包含結果集中查詢欄位較多的一個類,然後將其他需要的數據寫到這個子類中即可。

    

    創建pojo完成後,我們就需要根據規範去創建我們的映射文件和寫對應的介面中的方法:

    mapper.xml

    

    mapper.java中的介面:

    

 ResultMap

    sql語句上,resultType 和resuleMap實現的方式一樣,這裡就直接跳過了。

  使用resultMap映射的思路

    我們知道,使用pojo的時候,我們可以將一些數據封裝到pojo的對象屬性中,他的屬性可以是簡單類型,也可以是另外一個pojo。這時,我們可以這麼做:

    使用resultMap將查詢結果中的訂單信息映射到Orders對象中,在orders類中添加User屬性,將關聯查詢出來的用戶信息映射到orders對象中的user屬性中。

    Orders類中添加user屬性

    

  mapper.xml

    用resultMap的方法將結果集進行映射的時候,我們需要進行兩個操作,一個是定義resultMap,設置每個查到的結果集中的列相對應的對象的屬性。這個比較麻煩但是不難。二就是定義我們的statement。

   resultMap

    resultMap實現的基本思路我們剛纔已經說了。而且也在orders的pojo類中增加了相應的屬性了。接下啦,就是寫一個resultMap,將整個查詢的結果映射到Orders中在這裡面,首先是order訂單的映射。就是直接用id 和result標簽將兩者相互對應即可。然後就是,關聯的用戶信息的映射,這時候需要用到一個association的標簽,將在orders類中的user欄位與User類進行映射,然後在其內部還是用id和result標簽,將查詢的數據和User的屬性相映射。

    具體代碼如下:

    
 1 <!-- 訂單查詢關聯用戶的resultMap
 2     將整個查詢的結果映射到cn.mybatis.po.Orders中
 3      -->
 4     <resultMap type="cn.mybatis.po.Orders" id="OrdersUserResultMap">
 5         <!-- 配置映射的訂單信息 -->
 6         <!-- id:指定查詢列中的唯 一標識,訂單信息的中的唯 一標識,如果有多個列組成唯一標識,配置多個id
 7             column:訂單信息的唯 一標識 列
 8             property:訂單信息的唯 一標識 列所映射到Orders中哪個屬性
 9           -->
10         <id column="id" property="id"/>
11         <result column="user_id" property="userId"/>
12         <result column="number" property="number"/>
13         <result column="createtime" property="createtime"/>
14         <result column="note" property=note/>
15         
16         <!-- 配置映射的關聯的用戶信息 -->
17         <!-- association:用於映射關聯查詢單個對象的信息
18         property:要將關聯查詢的用戶信息映射到Orders中哪個屬性
19          -->
20         <association property="user"  javaType="cn.mybatis.po.User">
21             <!-- id:關聯查詢用戶的唯 一標識
22             column:指定唯 一標識用戶信息的列
23             javaType:映射到user的哪個屬性
24              -->
25             <id column="user_id" property="id"/>
26             <result column="username" property="username"/>
27             <result column="sex" property="sex"/>
28             <result column="address" property="address"/>
29         
30         </association>
31     </resultMap>
resultMap代碼

   statement

    statement比較簡單,就是將返回結果集的映射方式改成resultMap。然後將返回類型只想我們剛完成的resultMap就可以了。

    

  mapper.java

    

 兩者的區別

    實現一對一查詢的方法說完了,接下來分析下它們的不同之處,和優劣之處。

    首先,都需要對pojo進行修改,一個是增加一個pojo類另外一個則是修改pojo的欄位。個人感覺,根據設計模式中的開閉原則。resultType要比resultMap更好一些。

    其次,簡易程度上來說,使用resultType實現較為簡單。從這點講,resultType也要比resultMap更好一些。

    不過resultMap可以實現延遲載入,resultType無法實現延遲載入。這方面resultType就不如resultMap更好了。

    所以:建議大家,如果沒有查詢結果的特殊要求的話使用resultType。


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

-Advertisement-
Play Games
更多相關文章
  • 本文版權歸博客園和作者吳雙本人共同所有,轉載和爬蟲請註明原文地址 www.cnblogs.com/tdws 相信瞭解了MS Identity認證體系的一定知道UserManager的作用,他是整個體系中的調度者,他定義了一套用戶行為來幫助我們管理用戶信息,角色信息,處理密碼等。而其實現則在UserS ...
  • 鏈接:http://china.nba.com/playerindex/ 所需獲取JSON數據頁面鏈接:http://china.nba.com/static/data/league/playerlist.json 數據來源:NBA中國官網 庫: requests 用於解析頁面文本數據 pandas ...
  • 作為一名網路警察,你的任務是監視電子郵件,看其中是否有一些敏感的關鍵詞。不過,有些狡猾的犯罪嫌疑人會改變某些單詞的字母順序,以逃避檢查。請編寫一個程式,發現這種調整過順序的關鍵詞。程式的輸入有兩行,第一行是關鍵詞列表,第二行是待檢查的句子。程式的輸出為在該句子中所找到的經過順序調整的關鍵詞。(單詞全 ...
  • 轉載請標明出處: "http://www.cnblogs.com/why168888/p/6411664.html" 本文出自: "【Edwin博客園】" python進階介紹(進階1) 1. python基礎回顧 1. 安裝Python環境 2. 變數和數據類型:Python內置的基礎類型 3. ...
  • 內部類:在類中定義的類,外層的叫外部類、外圍類。 書中說P191,如果想在外部類的非靜態方法之外的任意位置創建某個內部類對象,那麼必須像在main方法(靜態方法)中那樣,具體地指明這個對象的類型:OuterClassName.InnerClassName。(在外部類非靜態方法中可以直接使用Inner ...
  • 分情況討論: 非const引用非const: 非同類型不能引用 非const引用const: 不能通過編譯。因為要引用,說明你要改值。。 const引用非const: 第一種情況:const引用與非const同類型。 很奇怪,這是可以通過編譯的!而且,const能變化值!(原因是引用並沒有綁定臨時值 ...
  • 本篇隨筆主要描述的是我閱讀 HashMap 源碼期間的對於 HashMap 的一些實現上的個人理解,用於個人備忘,有不對的地方,請指出~ 接下來會從以下幾個方面介紹 HashMap 源碼相關知識: 1、HashMap 存儲結構 2、HashMap 各常量、成員變數作用 3、HashMap 幾種構造方 ...
  • 需求按優先順序順序如下: 1)存放3TB以上中小型文件,圖片為主,平均在500~700k,一般在1M以內。 2)要集群化,支持負載均衡,高可用高性能。有大企業使用背書最好。 3)提供Java程式上傳文件的手段。Java代碼可以在Windows環境下調試。 4)必須開源,作者能保持更新。 5)有運維監控 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...