mongodb數據庫之連表查詢

在作本身的項目時,由於剛開始接觸mongodb非關係型數據庫以及關係型數據庫的影響仍是留在腦中,總會想着進行一個連表查詢,而後看官網和資料學習了下,還有那個查詢時使用正則來匹配,在這裏作個記錄

1.mongodb正則匹配

/* 使用$regex字段匹配 */
name: {$regex: 'aa', $options: 'i'};
或者:
name: {$regex: /aa/, $options: 'i'};
或者:
name: {$regex: /aa/i};
/* 直接使用表達式 */
name: {/aa/i}
/* 使用$in來匹配,這個字段必須是一個數組 */
name: {$in: [/aa/]}

2.連表查詢

  • 使用$lookup來進行連表查詢
/* aggregate聚合操做,$unwind將數組拆分紅單個元素
 * $group 分組依據
 * $sum 統計
 * $project 將返回值進行篩選,是否返回篩選完後的某個字段
 * $match 匹配條件
 * */
usingRecord.aggregate([
    {
      $lookup: {
        from: 'resources', /* 要鏈接的表名 */
        localField: 'resource_id', /* 當前表對應的字段 */
        foreignField: '_id', /* 要鏈接的表的字段 */
        as: 'resourceInfo'  /* 查詢結果中顯示的字段名 */
      },
    },
    {
      $match: {
        'user_id': user_id
      }
    },
    {
      $unwind: '$resourceInfo'
    },
    {
      $sort: {
        _id: -1
      }
    }
  ])

3.小結

  • mongodb數據庫是非關係型、文檔型數據庫,將有關聯的數據存儲在一份文檔中就可以減小進行表與表之間的關聯查詢
  • 本身先在網上找資料學習後,而後在學習慕課網上的視頻時,就有很大的感觸,目前的話仍是有一些迷惑,對於數據的插入我會找到更好的方法來實現
正在努力學習中,若對你的學習有幫助,留下你的印記唄(點個贊咯^_^)
相關文章
相關標籤/搜索