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

基于mybatis高級映射多對多查詢的實現(xiàn)

 更新時間:2017年10月24日 09:48:09   作者:代江平  
下面小編就為大家?guī)硪黄趍ybatis高級映射多對多查詢的實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

1.同以前一樣,首先給一個使用多對多的需求,

要查詢用戶以及用戶所購買的商品信息,經(jīng)過分析用戶和商品數(shù)據(jù)庫級別沒有任何關(guān)系,用戶和商品需要建立關(guān)系,要通過訂單,訂單明細建立關(guān)系。根據(jù)這個需求,可以分析出需要查詢的主表為:

查詢主表:用戶表

查詢關(guān)聯(lián)表:由于商品和用戶沒有關(guān)系,通過訂單和訂單明細進行關(guān)聯(lián),所以得出關(guān)聯(lián)表是:orders訂單表,orderDetail訂單明細表,items商品表。這樣的話,sql該如何去寫?這樣寫:

select
      orders.*,
      t_user.id user_id,
      t_user.address,
      t_user.name,
      t_user.brithday,
      orderdetail.id orderdetail_id,
      orderdetail.orderid,
      orderdetail.itemsid,
      items.id items_id,
      items.name items_name,
      items.price items_price
      from
      orders,
      t_user,
      orderdetail,
      items
      where
      orders.userid=t_user.id AND orderdetail.orderid=orders.id AND orderdetail.itemsId = items.id

為了方便映射,適當加上別名,上面就是寫好的大sql,這sql語句是越來越大了,但不要害怕,待會做映射一個個來做,只要方法得提是很簡單的。

2.編寫映射文件分析:

現(xiàn)在的主表是user,所以將用戶 的信息映射到user中,一個用戶可以創(chuàng)建多個訂單,所以在user屬性中添加List<Orders> orderlist 屬性,這和hibernate越來越像了哈,然后將用戶創(chuàng)建的訂單映射到orderlist,中一個訂單可以包括多個訂單明細,所以在orderS中添加訂單明細列表屬性:List<OrderDetail> orderdetails ,一個訂單明細只包括一個商品信息,所以在OrderSDetail中添加商品items 屬性。

User.java代碼如下:

public class User {
  private int id;
  private String name;
  private String pwd;
  private String address;
  private Date brithday;
  private List<Orders> ordersList;//看這里 用戶創(chuàng)建的訂單列表
}

Orders.java代碼如下:

public class Orders {
  private int id;
  private String note;
  private Date dateTime;
  private String number;
  private int userId;
  private User user;
  private List<OrdersDetail> ordersDetails;//一個訂單包括多個訂單明細

OrdersDetail.java代碼如下:

public class OrdersDetail {
  private int id;
  private int orderId;
  private int itemsId;
  private Items items;//一條訂單明細包括一條商品信息  

到這里,pojo類之間的關(guān)系就搭建好了,接下來寫mapper.xml

代碼如下(注意看代碼里的注釋):

<!--查詢用戶所購買的商品信息resultMap-->
  <resultMap id="UserAndItemsResultMap" type="com.djp.pojo.User">
    <!--配置用戶信息-->
    <id column="user_id" property="id"/>
    <result column="address" property="address"/>
    <result column="name" property="name"/>
    <result column="brithday" property="brithday"/>
    <!--配置用戶創(chuàng)建的訂單信息,一個用戶創(chuàng)建了多個訂單-->
    <collection property="ordersList" ofType="com.djp.pojo.Orders">
      <id column="id" property="id"/>
      <result column="note" property="note"/>
      <result column="dateTime" property="dateTime"/>
      <result column="userId" property="userId"/>
      <result column="number" property="number"/>
      <!--配置訂單明細信息 一個訂單包含多個訂單明細-->
      <collection property="ordersDetails" ofType="com.djp.pojo.OrdersDetail">
        <id column="orderdetail_id" property="id"/>
        <result column="orderId" property="orderId"/>
        <result column="itemsid" property="itemsId"/>
        <!--配置商品信息 一個明細包括一個商品-->
        <association property="items" javaType="com.djp.pojo.Items">
          <id column="items_id" property="id"/>
          <result column="items_name" property="name"/>
          <result column="items_price" property="price"/>
        </association>
      </collection>
    </collection>
  </resultMap>
  <!--查詢用戶所購買的商品信息-->
  <select id="findUserAndItemsResultMap" resultMap="UserAndItemsResultMap">
    select
      orders.*,
      t_user.id user_id,
      t_user.address,
      t_user.name,
      t_user.brithday,
      orderdetail.id orderdetail_id,
      orderdetail.orderid,
      orderdetail.itemsid,
      items.id items_id,
      items.name items_name,
      items.price items_price
      from
      orders,
      t_user,
      orderdetail,
      items
      where
      orders.userid=t_user.id AND orderdetail.orderid=orders.id AND orderdetail.itemsId = items.id
  </select>

有了之前一對多的映射,類比寫這個就比較簡單了;這里不能使用繼承,因為你發(fā)現(xiàn)使用繼承沒法套用了。所以只能老實的寫完。

接下來在接口中添加一個方法,為查詢用戶所購買商品信息

public interface OrdersCustomMapper {
  /**
   * 查詢用戶所購買的商品
   * @return
   * @throws Exception
   */
  List<User> findUserAndItemsResultMap() throws Exception;

最后一步,寫測試類:

/**findUserAndItemsResultMap
   * 查詢用戶所購買的商品信息
   */
  @Test
  public void testfindUserAndItemsResultMap() {
    try {
      System.out.println("start.................");
      //通過得到的SqlSessionFactory打開回話sqlSession
      SqlSession sqlSession = SqlSessionFactory.openSession();
      //通過會話得到用戶的代理
      OrdersCustomMapper ordersCustomMapper = sqlSession.getMapper(OrdersCustomMapper.class);
      List<User> list = ordersCustomMapper.findUserAndItemsResultMap();
      System.out.println("end.................");
    } catch (Exception e) {
      e.printStackTrace();
    }
  }

運行,結(jié)果如下:

用戶商品.png可以看到我展開的列表,是不是想要的數(shù)據(jù)都出來了;

總結(jié):

到這里可能有人會覺得這個怎么比hibernate中的多對多還麻煩,那么,現(xiàn)在如果有這么一個需求,查詢用戶所購買的商品信息明細清單(用戶名,用戶地址,購買商品名稱,購買商品時間,購買商品數(shù)量),這個時候應(yīng)該使用resultMap還是resulType,這個時候會發(fā)現(xiàn),針對上面的需求,就是用resultType將查詢到的信息映射到一個擴展的pojo中,很好用,加屬性就行了,這樣的話就可以很簡單地實現(xiàn)明細清單的功能,比如話費賬單,張三幾點幾分給誰打電話,張三幾點幾分打電話給誰,沒必要去重復(fù)記錄。所以,要根據(jù)需求來,并非所有的一對多都是上面的resultMap那種查詢。使用resultMap是針對那些查詢結(jié)果有特殊要求的功能,比如映射成list中還包括多個list。

一對多是多對多的特咧:查詢用戶購買商品信息,用戶和商品是多對多關(guān)系。

需求1:查詢字段:用戶賬號,用戶名稱,用戶性別,商品名稱,商品價格(最常見)。企業(yè)開發(fā)中常見的明細表,用戶購買商品明細表等。

方法:使用resultType將上面商品輸出

需求2:查詢字段:用戶賬號,用戶名稱,購買商品數(shù)量,商品明細(鼠標移動到上面顯示明細)

方法:使用resultMap將用戶所購買的商品明細映射到user中。

對resultMap的大總結(jié):

resultType:

作用:將查詢結(jié)果按照sql列名和pojo屬性名一致映射到pojo中

場合:常見的一些明細記錄的展示,比如用戶購買商品的明細,將關(guān)聯(lián)查詢的信息全部展示在頁面時,此時用resultType將每一條記錄映射到pojo中,在前端頁面遍歷list即可。

resultMap:

使用association和collection完成一對一和一對多的高級映射(對結(jié)果有特殊要求)。

association:

作用:將關(guān)聯(lián)查詢的信息映射到一個pojo中

場合:為了方便查詢關(guān)聯(lián)信息可以使用association將關(guān)聯(lián)訂單信息映射為用戶對象的pojo屬性中,比如:查詢訂單關(guān)聯(lián)查詢用戶信息。

collection:

作用:將關(guān)聯(lián)查詢用戶信息映射到一個list集合中

場合:為了方便查詢遍歷關(guān)聯(lián)信息可以使用collection將關(guān)聯(lián)信息映射到list集合中,比如:查詢用戶權(quán)限范圍模塊以及模塊下的菜單,可以使用collection將模塊映射到list中,將菜單列表遍歷即可!

以上這篇基于mybatis高級映射多對多查詢的實現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot獲取客戶端的IP地址的實現(xiàn)示例

    SpringBoot獲取客戶端的IP地址的實現(xiàn)示例

    在Web應(yīng)用程序中,獲取客戶端的IP地址是一項非常常見的需求,本文主要介紹了SpringBoot獲取客戶端的IP地址的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • Java利用endorsed如何覆蓋jdk提供的類詳解

    Java利用endorsed如何覆蓋jdk提供的類詳解

    這篇文章主要給大家介紹了關(guān)于Java利用endorsed如何覆蓋jdk提供的類的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • Java中Hashtable集合的常用方法詳解

    Java中Hashtable集合的常用方法詳解

    本篇文章給大家?guī)淼膬?nèi)容是關(guān)于Java中Hashtable集合的常用方法詳解,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。下面我們就來學(xué)習(xí)一下吧
    2021-11-11
  • java代碼獲取數(shù)據(jù)庫表里數(shù)據(jù)的總數(shù)操作

    java代碼獲取數(shù)據(jù)庫表里數(shù)據(jù)的總數(shù)操作

    這篇文章主要介紹了java代碼獲取數(shù)據(jù)庫表里數(shù)據(jù)的總數(shù)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • microlog4android將Android Log日志寫到SD卡文件中實現(xiàn)方法

    microlog4android將Android Log日志寫到SD卡文件中實現(xiàn)方法

    這篇文章主要介紹了microlog4android將Android Log日志寫到SD卡文件中實現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • SpringCloud Alibaba框架介紹

    SpringCloud Alibaba框架介紹

    spring cloud是一個基于springboot實現(xiàn)的微服務(wù)架構(gòu)開發(fā)工具,目前主流的SpringCloud分為SpringCloud Netflix和阿里云開源的SpringCloud Alibaba兩個系列,本文主要介紹SpringCloud Alibaba框架,感興趣的朋友可以參考一下
    2023-04-04
  • SpringBoot獲取前臺參數(shù)的六種方式以及統(tǒng)一響應(yīng)

    SpringBoot獲取前臺參數(shù)的六種方式以及統(tǒng)一響應(yīng)

    本文主要介紹了SpringBoot獲取前臺參數(shù)的六種方式以及統(tǒng)一響應(yīng),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • java多線程join()方法的作用和實現(xiàn)原理解析(應(yīng)用場景)

    java多線程join()方法的作用和實現(xiàn)原理解析(應(yīng)用場景)

    join方法主要是用于將當前線程掛起,等待其他線程結(jié)束后在執(zhí)行當前線程,本文通過應(yīng)用場景分析代碼示例講解java多線程join()方法的作用和實現(xiàn)原理,感興趣的朋友一起看看吧
    2021-07-07
  • Java中可變長度參數(shù)代碼詳解

    Java中可變長度參數(shù)代碼詳解

    這篇文章主要介紹了Java中可變長度參數(shù)代碼詳解,涉及了實參個數(shù)可變的定義方法,數(shù)組包裹實參等幾個問題,具有一定參考價值,需要的朋友可以了解下。
    2017-12-12
  • SpringBoot使用過濾器、攔截器和監(jiān)聽器的案例代碼(Springboot搭建java項目)

    SpringBoot使用過濾器、攔截器和監(jiān)聽器的案例代碼(Springboot搭建java項目)

    這篇文章主要介紹了SpringBoot使用過濾器、攔截器和監(jiān)聽器(Springboot搭建java項目),本文是基于Springboot搭建java項目,結(jié)合案例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02

最新評論