欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java操作mongodb之多表聯(lián)查的實現(xiàn)($lookup)

 更新時間:2021年03月31日 10:45:47   作者:要么出眾,要么出局  
這篇文章主要介紹了java操作mongodb之多表聯(lián)查的實現(xiàn)($lookup),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

最近在開發(fā)的過程中,一個列表的查詢,涉及到了多表的關(guān)聯(lián)查詢,由于持久層使用的是mongodb,對這個非關(guān)系型數(shù)據(jù)使用的不是很多,所以在實現(xiàn)此功能的過程中出現(xiàn)了不少問題,現(xiàn)在此做記錄,一為加深自己的理解,以后遇到此類問題可以快速的解決,二為遇到同樣問題的小伙伴提供一點(diǎn)小小的幫助。

全文分為兩部分:

  1. 使用robo3t編寫多表關(guān)系的查詢語句
  2. 將編寫的查詢語句整合到j(luò)ava項目

多表聯(lián)查的查詢語句:

此處使用的為mongodb的robo3t可視化工具,先說下需求:從A(假如說是日志表)表中查詢出符合條件的數(shù)據(jù),根據(jù)A表中符合條件數(shù)據(jù)查詢B(假如說是信息表)表中的數(shù)據(jù),此處也可以將B表的查詢條件加入進(jìn)來(類型于關(guān)系型數(shù)據(jù)庫中的臨時表)

mongo查詢語句:

db.getCollection('A').aggregate([
    {
    $lookup:{
          from:'B',
          localField:'userid',
          foreignField:'userid',
          as:'userinfo'
        }
    }, 
    {
     $unwind:'$userrole'//把一個數(shù)組展成多個,就比如說按多表連查的userrole數(shù)組中有10數(shù)據(jù),那么用$unwind將把一條帶數(shù)組的數(shù)據(jù)分成10條,這10條數(shù)據(jù)除了userrole不同之外,其它數(shù)據(jù)都是相同的,就類似于一個展開操作
    },
    {
     $match:{'username':'zhangsan'}
    },
    {
     $group:{
          _id:{
              userid:'$userid',//這個屬性必須是要A表中有的
              userrole:'$userrole.roleid',//A表中有一個集合,里面存放的對象有一個名為roleid的屬性
            },
          operateTime:{
              $last:'$operateTime'//取A表操作時間最后一條件數(shù)
            }
          info:{
              $first:'$userinfo'//因為數(shù)組的擴(kuò)展,造成了大量的重復(fù)數(shù)據(jù)(只有userrole不同),$first是只取最新的一條
            }
        }
    },
    {
      $sort:{'operateTime':-1}//操作時間倒序,-1:倒序,1:升序
    },
    {
      $skip:0//跳過幾條數(shù)據(jù),也就是從第幾條數(shù)據(jù)開始取
    },
    {
      $limit:5//每頁顯示幾條數(shù)據(jù)
    }
]);

java代碼整合查詢語句

//定義分組字段
String[] groupIds = new String[] {"$userid","$userrole.roleid"};
//定義查詢條件
Criteria criteria = new Criteria();
//相當(dāng)于where username = "zhangsan"
criteria.and("username").is("zhangsan");
//相當(dāng)于 where age not in("15","20")
criteria.and("age").nin("15","20");
//in操作對應(yīng)的語句
//criteria.and("").in();
//定義排序條件
Sort sort = new Sort(Direction.DESC,"operateTime");
//聯(lián)合查詢總條數(shù),分頁用
Aggregation aggregationCount = Aggregation.newAggregation(
  Aggregation.match(criteria);//查詢條件
  Aggregation.group(groupIds);//分組字段
);
//聯(lián)合查詢條件
Aggregation newAggregation = Aggregation.newAggregation(
  Aggregation.lookup('B','userid','userid','userinfo'),//從表名,主表聯(lián)接字段,從表聯(lián)接字段,別名
  Aggregation.unwind("$userrole"),
  Aggregation.match(criteria),
  Aggregation.group(groupIds)
    .last("$operateTime").as("operateTime")//取值,起別名
    .first("$userinfo").as("info"),
  Aggregation.sort(sort),
  Aggregation.skip(pageSize*(pageNumber-1L)),//Long類型的參數(shù)
  Aggregation.limit(pageSize)
);
//查詢
AggregationResults<BasicDBObject> aggregate = mongoTemplate.aggregate(
  newAggregation ,"A",BasicDBObject.class//A表,是查詢的主表
);
int count = mongoTemplate.aggregate(aggregationCount ,"A",BasicDBObject.class).getMappedResults().size();
//組裝分頁對象
Page<BasicDBObject> pager = new Page<>(aggregate.getMappedResults(),count,pageSize,pageNumber,page*(pageNumber-1));
//對象轉(zhuǎn)換
將BasicDBObject轉(zhuǎn)換成前面需要的類型.....

到此這篇關(guān)于java操作mongodb之多表聯(lián)查的實現(xiàn)($lookup)的文章就介紹到這了,更多相關(guān)java mongodb多表聯(lián)查內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 一文搞懂Spring中Bean的生命周期

    一文搞懂Spring中Bean的生命周期

    這篇文章主要為大家介紹了Spring中Bean生命周期的使用及控制,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)或工作有一定的參考價值,感興趣的可以學(xué)習(xí)一下
    2022-06-06
  • 細(xì)致解讀希爾排序算法與相關(guān)的Java代碼實現(xiàn)

    細(xì)致解讀希爾排序算法與相關(guān)的Java代碼實現(xiàn)

    這篇文章主要介紹了希爾排序算法與相關(guān)的Java代碼實現(xiàn),希爾排序的時間復(fù)雜度根據(jù)步長序列的不同而不同,需要的朋友可以參考下
    2016-05-05
  • java連接數(shù)據(jù)庫的5種方式解讀

    java連接數(shù)據(jù)庫的5種方式解讀

    這篇文章主要介紹了java連接數(shù)據(jù)庫的5種方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教<BR>
    2024-04-04
  • 在spring?boot3中使用native?image的最新方法

    在spring?boot3中使用native?image的最新方法

    這篇文章主要介紹了在spring?boot3中使用native?image?,今天我們用具體的例子來給大家演示一下如何正確的將spring boot3的應(yīng)用編譯成為native image,需要的朋友可以參考下
    2023-01-01
  • JVM虛擬機(jī)的類加載機(jī)制詳解

    JVM虛擬機(jī)的類加載機(jī)制詳解

    這篇文章主要介紹了JVM虛擬機(jī)的類加載機(jī)制詳解,類是在運(yùn)行期間第一次使用時動態(tài)加載的,而不是一次性加載所有類,因為如果一次性加載,那么會占用很多的內(nèi)存,需要的朋友可以參考下
    2023-12-12
  • java中StringBuffer的length()和capacity()方法對比

    java中StringBuffer的length()和capacity()方法對比

    這篇文章主要介紹了java中StringBuffer的length()和capacity()方法對比,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Mybatis在注解上如何實現(xiàn)動態(tài)SQL

    Mybatis在注解上如何實現(xiàn)動態(tài)SQL

    這篇文章主要介紹了Mybatis在注解上如何實現(xiàn)動態(tài)SQL,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • javaSE基礎(chǔ)java自定義注解原理分析

    javaSE基礎(chǔ)java自定義注解原理分析

    這篇文章主要介紹了javaSE基礎(chǔ)對java自定義注解原理分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多度進(jìn)步,早日升職加薪
    2021-10-10
  • java中JVM中如何存取數(shù)據(jù)和相關(guān)信息詳解

    java中JVM中如何存取數(shù)據(jù)和相關(guān)信息詳解

    這篇文章主要介紹了JVM中如何存取數(shù)據(jù)和相關(guān)信息詳解,Java源代碼文件(.java后綴)會被Java編譯器編譯為字節(jié)碼文件,然后由JVM中的類加載器加載各個類的字節(jié)碼文件,加載完畢之后,交由JVM執(zhí)行引擎執(zhí)行。JVM中怎么存取數(shù)據(jù)和相關(guān)信息呢?,需要的朋友可以參考下
    2019-06-06
  • 圖文詳解Java的反射機(jī)制

    圖文詳解Java的反射機(jī)制

    反射就是Reflection,Java的反射是指程序在運(yùn)行期可以拿到一個對象的所有信息。反射機(jī)制是框架的靈魂,一個java程序員不能不會使用反射,本文就來和大家一起詳細(xì)聊聊Java的反射機(jī)制
    2022-08-08

最新評論