主頁 > 知識庫 > mongodb中非常好用的Aggregate入門教程

mongodb中非常好用的Aggregate入門教程

熱門標(biāo)簽:外呼線路資源屬于電信業(yè)務(wù)嗎 crm外呼系統(tǒng)聯(lián)系方式 河南電話外呼系統(tǒng)招商 青白江400企業(yè)電話申請 智能外呼系統(tǒng)官網(wǎng) 呼和浩特外呼系統(tǒng)原理是什么 長沙電銷外呼防封卡是什么 小裙科技電銷機(jī)器人怎樣 內(nèi)蒙古營銷智能外呼系統(tǒng)哪個(gè)好

前言

aggregate 翻譯過來是聚合的意思, 但是在實(shí)際的使用的它的體驗(yàn)特別像linux中的管道, 每個(gè)管道處理完之后再把結(jié)果交個(gè)下一個(gè)管道, 你的數(shù)據(jù)就像水流, 最后通過各個(gè)管道你能夠得到你想要的數(shù)據(jù)

我們一般用Aggregate做什么

aggregate查詢文檔

  • 聚合 平均數(shù) 等數(shù)據(jù)處理 group sum
  • 地理位置信息 $geoNear
  • 基本上mongodb的所有查詢操作我們都可以用 aggregate實(shí)現(xiàn), 用好這個(gè)基本上是萬金油了

在這里我主要想記錄一下mongodb在地理位置信息查詢中使用到的技術(shù),不僅可以查詢到 距離 還可以按照距離排序

$geoNear 地理位置信息查詢

首先我們的坐標(biāo)數(shù)據(jù)在庫里面怎么存, 類型為 Array , 記得加 2d 索引, 當(dāng)然還有3d 索引, 目前還沒有用到

 const storeschema = new mongoose.Schema({
  name: { type: String, required: true },
  point: { type: Array, required: true }, // [lon, lat]
 });
 storeschema.index({ point: '2d' });
 return mongoose.model('store', storechema);

然后按照就是地理查詢代碼了

this.ctx.model.Store.aggregate([{
    $geoNear: {
     spherical: true, // spherical 是否按照球形狀來求距離
     distanceMultiplier: 6378137, 
     maxDistance: 10000,
     near: [ lon1, lat1 ],
     distanceField: 'dist',
     key: 'point',
     query: {
     }
    },
 },
 //distanceMultiplier 這個(gè)參數(shù)是用于確定你返回的距離是什么單位 6378137 的單位是m
 //maxDistance 查詢的最大距離 
// near 中心點(diǎn)坐標(biāo)
// distanceField 距離放在哪個(gè)屬性
// key 保存坐標(biāo)數(shù)據(jù)的地方
// query 你的過濾條件                

有一個(gè)很有意思的地方是 match 所以在這里有一個(gè) query屬性來補(bǔ)齊這種遺憾

但是你可以在   后面 使用$match 對查到的所有地理位置信息數(shù)據(jù)做再一次的篩選

$lookup mongodb中的聯(lián)表查詢

$lookup 是在比較新的mongodb版本中才能使用的屬性, 當(dāng)然這個(gè)屬性也是用于 aggregate中的, 它補(bǔ)齊了之前mongodb中無法聯(lián)表的遺憾

看代碼

await this.ctx.model.MemberInfo.aggregate([
        {
          $match: { store: new ObjectId(store) }
        },
        {
          $lookup: {
            from: 'users',
            localField: 'user',
            foreignField: '_id',
            as: 'user'
          }
        },
        {
          $replaceRoot: { newRoot: { $mergeObjects: [{ $arrayElemAt: [ '$user', 0 ] }, '$$ROOT' ] } }
        },
        {
          $match: { 'certification.name': { $regex: search } }
        },
        {
          $project: { _id: 1 }
        }
      ]);

memberinfo 與 user 表在這里我想要獲取 memberinfo  localField: 'user' 為外鍵對應(yīng) user表 foreignField: '_id' _id字段他的額外屬性...

說白了 我的會(huì)員表里面只存了用戶的id  現(xiàn)在我想要拿到用戶的 其它信息...

附上鏈接吧 $lookup

寫在最后

當(dāng)然說他是查詢?nèi)f金油他當(dāng)然支持 定義數(shù)據(jù)的輸出  limit $sort 等常規(guī)操作

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • MongoDB入門教程之C#驅(qū)動(dòng)操作實(shí)例
  • MongoDB入門教程之常用的運(yùn)維技術(shù)介紹
  • MongoDB入門教程之分片技術(shù)詳解
  • MongoDB入門教程之主從復(fù)制配置詳解
  • MongoDB入門教程之索引操作淺析
  • MongoDB入門教程之聚合和游標(biāo)操作介紹
  • MongoDB入門教程之細(xì)說MongoDB數(shù)據(jù)庫的增刪查改操作
  • MongoDB入門教程之Windows下的MongoDB數(shù)據(jù)庫安裝圖解
  • MongoDB入門教程(包含安裝、常用命令、相關(guān)概念、使用技巧、常見操作等)
  • MongoDB 簡單入門教程(安裝、基本概念、創(chuàng)建用戶)

標(biāo)簽:池州 黃石 安順 舟山 菏澤 呼倫貝爾 楚雄 白山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mongodb中非常好用的Aggregate入門教程》,本文關(guān)鍵詞  mongodb,中,非常好,用的,Aggregate,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mongodb中非常好用的Aggregate入門教程》相關(guān)的同類信息!
  • 本頁收集關(guān)于mongodb中非常好用的Aggregate入門教程的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章