成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

MongoDB 高級查詢

Lin_YT / 1590人閱讀

摘要:格式為查詢條件顯示與否的選項如排序可以按指定的某些字段排序,字段標記為的為升序,標記為的為降序。查詢條件消除重復使用函數(shù)。格式為集合名指定字段查詢條件如聚合管道是特有的一種管道型聚合查詢方式。

參考官方文檔(圖文并茂非常好看):Getting Started - MongoDB Documentation

MongoDB的查詢功能非常強大,同時有些地方也會有點復雜。所以需要下點功夫?qū)W習和操練才能用好。

關于Mongo Shell

當我們進入Mongo Shell客戶端后,實際上是進入了一個Javascript語言的交互環(huán)境。
也就是說,MongoDB中的很多命令,尤其是包括定義函數(shù)等高級命令,實際上都是Javascript語言,甚至說可以是jQuery。
了解了這點,一些高級命令如Aggregation學起來就會放松很多。

官方說明:

基本查詢功能 比較運算

: 等于

$lt: Less Than

$gt: Greater Than

$gte: Greater Than or Equal

$ne: Not Equal

# age大于等于18
db.mycollection1.find( { age:{$gt: 18} } )
邏輯運算

$and

$or

db.mycollection1.find( {
    $or: [
        { age: {$gte: 20} },
        { salary: {$gt: 5000} },
        { job: "HR" }
    ]
} )
范圍運算

$in

$nin: Not In

db.mycollection1.find( {
    age: {
        $in: [10, 20, 30]
    }
} )
正則表達式

有兩種方法:

/表達式內(nèi)容/

{$regex: "表達式內(nèi)容"}

db.mycollection1.find( {
    name: /^Jaw+$/
} )

# 或
db.mycollection1.find( {
    name: {
        $regex: "/^Jasow?$"
    }
} )
limit和skip
# 限定顯示條數(shù)
db.mycollection1.find().limit(數(shù)量)

# 跳過指定第幾條數(shù)據(jù)
db.mycollection1.find().skip(2)

# 混合使用
db.mycollection1.find().limit(10).skip(3)
自定義函數(shù)查詢

自定義查詢是指使用自定義函數(shù),格式為$where: function(){...}

db.mycollection1.find( {
    $where: function() {
        return this.age >= 18;
    }
} )
投影

即搜索的返回值中,只顯示指定的某些字段。字段指為0的不現(xiàn)實,指為1的顯示,默認為1。

# 格式為:
db.mycollection1.find(
    {查詢條件},
    {顯示與否的選項}
)

# 如:
db.mycollection1.find(
    {},
    { _id: 0, name: 1, age: 1 }
)
排序

可以按指定的某些字段排序,字段標記為1的為Asc升序,標記為-1的為Desc降序。

db.mycollection1.find().sort({  name:1, age:-1 })
統(tǒng)計

使用count()函數(shù)。

db.mycollection1.find().count()

db.mycollection1.count( {查詢條件} )
消除重復

使用distinct()函數(shù)。

# 格式為:
db.集合名.distinct( "指定字段", {查詢條件} )

# 如
db.mycollection1.distinct( 
    "job", 
    { age: {$lt: 40} } 
)
聚合管道 Aggregation

Aggregation是MongoDB特有的一種Pipline管道型、聚合查詢方式。語法稍微復雜一些。

聚合管道可以達到多步驟的分組、篩選功能。這個管道中的每一個步驟,成為一個stage。

常用的管道有:

$match:簡單的根據(jù)條件過濾篩選

$group:將數(shù)據(jù)分組,一般配合一些統(tǒng)計函數(shù),如$sum。

$project:修改document的結構。如增刪改,或創(chuàng)建計算結果

$lookup

$unwind:將List列表類型的Document進行拆分

$sort

$limit

$skip

語法格式為:

db.集合名.aggregate( [
    {管道表達式1},
    {管道表達式2},
    {管道表達式2}
] )

示例:

db.Orders.aggregate( [
    {$match: {
        status: "A"
    } },
    {$group: {
        _id: "$cut_id",
        total: { $sum: "$amount" }
    } }
] )

管道的Map Reduce

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/19454.html

相關文章

  • SpringBoot高級MongoDB之如何新增文檔

    摘要:本篇博文為的中一篇,前面介紹簡單的查詢使用,這一篇重點則放在插入數(shù)據(jù)基本使用首先是準備好基本環(huán)境,可以參考博文高級篇之基本環(huán)境搭建與使用高級篇之查詢基本使用姿勢新增一條數(shù)據(jù)一個基本數(shù)據(jù)稱為,和不一樣,沒有強制約束哪些字段,可以隨 本篇博文為mongodb的curd中一篇,前面介紹簡單的查詢使用,這一篇重點則放在插入數(shù)據(jù); I. 基本使用 首先是準備好基本環(huán)境,可以參考博文 1812...

    sherlock221 評論0 收藏0
  • 一篇文章入門MongoDB

    摘要:既是數(shù)據(jù)庫,又是內(nèi)存數(shù)據(jù)庫,而且它是現(xiàn)在最強大最流行的數(shù)據(jù)庫。所以相對于的真內(nèi)存數(shù)據(jù)庫而言,只是將大部分的操作數(shù)據(jù)存在內(nèi)存中。 MongoDB既是NoSQL數(shù)據(jù)庫,又是內(nèi)存數(shù)據(jù)庫,而且它是現(xiàn)在最強大、最流行的NoSQL數(shù)據(jù)庫。區(qū)別與別的NoSQL數(shù)據(jù)庫,MongoDB主要是基于Documents文檔(即一條JSON數(shù)據(jù))的。 MongoDB的特點: NoSQL數(shù)據(jù)庫 內(nèi)存數(shù)據(jù)庫 存儲...

    felix0913 評論0 收藏0
  • MongoDB ( 三 )高級_狀態(tài)返回和安全

    摘要:應答式寫入就會給我們返回結果,結果里面包含的項目很多,這樣我們就能更好的進行程序的控制和安全機制的處理。如下這個有用的另外一個用法命令行中使用該命令查看數(shù)據(jù)庫是否連接成功返回表示數(shù)據(jù)庫連接成功是查找并修改的意思。 在操作數(shù)據(jù)庫時,對數(shù)據(jù)的修改是需要有足夠的安全措施的,其實在實際工作中,我們用db.collections.update的時候不多,在修改時我們都會用findAndModif...

    superPershing 評論0 收藏0
  • MongoDB ( 四 )高級_find修飾符

    摘要:返回內(nèi)容查詢出來后顯示的結果樣式,可以用和控制是否顯示。修飾符文件使用進行鏈接對應的集合聲明變量,并把查詢結果賦值給利用游標的進行循環(huán)輸出結果。到此的基礎操作就結束了,但是我們還沒有結束呢,下一節(jié)我們會用配合使用哦 find查詢操作是我們平時再開發(fā)中最常用的,也是重中之重。 find基本操作符 // 批量插入數(shù)據(jù) var workmate1={ name:JSPang, ag...

    crossea 評論0 收藏0
  • MongoDB ( 五 )高級_索引

    摘要:插入兩條數(shù)據(jù)建立全文索引需要注意的是這里使用關鍵詞來代表全文索引,我們在這里就不建立數(shù)據(jù)模型了。全文索引查找表示要在全文索引中查東西。全文索引在工作還是經(jīng)常使用的,比如博客文章的搜索,長文件的關鍵詞搜索,這些都需要使用全文索引來進行。 索引 在認識索引的之前我們先建立一張表,并往其中插入200萬條數(shù)據(jù)。 // test.js //生成隨機數(shù) function GetRandomNum(...

    focusj 評論0 收藏0

發(fā)表評論

0條評論

Lin_YT

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<