日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
MongoDB高級索引
假如在 users 集合中插入以下文檔:

> db.users.insert(
... {
... "address": {
... "city": "Hebei",
... "country": "China",
... "postcode": "000000"
... },
... "tags": [
... "music",
... "cricket",
... "blogs"
... ],
... "name": "bianchengbang"
... }
... )
WriteResult({ "nInserted" : 1 })

在上面的文檔中包含了一個名為 address 的子文檔和一個名為 tags 的數(shù)組。

索引數(shù)組字段

假設(shè)要想根據(jù)集合內(nèi) tags 字段中的某個值來搜索用戶文檔,就需要我們?yōu)榧现械?tags 字段創(chuàng)建索引。想要在數(shù)組類型的字段上創(chuàng)建索引,需要為數(shù)組中的每個字段依次創(chuàng)建單獨(dú)的索引。

在下面的示例中,當(dāng)我們在 tags 字段上創(chuàng)建索引時,MongoDB 會自動在 music、cricket 和 blogs 等值上創(chuàng)建單獨(dú)的索引。

> db.users.createIndex({"tags":1})
{
        "createdCollectionAutomatically" : false,
        "numIndexesBefore" : 2,
        "numIndexesAfter" : 3,
        "ok" : 1
}

索引創(chuàng)建成功后,我們可以像下面這樣來搜索集合中的文檔:

> db.users.find({tags:"cricket"}).pretty()
{
        "_id" : ObjectId("603f571d5e514debed504a39"),
        "address" : {
                "city" : "Hebei",
                "country" : "China",
                "postcode" : "000000"
        },
        "tags" : [
                "music",
                "cricket",
                "blogs"
        ],
        "name" : "bianchengbang"
}

若要驗證在搜索的過程中是否正確的使用了索引,可以使用前面介紹的 explain() 方法。

> db.users.find({tags:"cricket"}).explain()
{
        "queryPlanner" : {
                "plannerVersion" : 1,
                "namespace" : "bianchengbang.users",
                "indexFilterSet" : false,
                "parsedQuery" : {
                        "tags" : {
                                "$eq" : "cricket"
                        }
                },
                "winningPlan" : {
                        "stage" : "FETCH",
                        "inputStage" : {
                                "stage" : "IXSCAN",
                                "keyPattern" : {
                                        "tags" : 1
                                },
                                "indexName" : "tags_1",
                                "isMultiKey" : true,
                                "multiKeyPaths" : {
                                        "tags" : [
                                                "tags"
                                        ]
                                },
                                "isUnique" : false,
                                "isSparse" : false,
                                "isPartial" : false,
                                "indexVersion" : 2,
                                "direction" : "forward",
                                "indexBounds" : {
                                        "tags" : [
                                                "[\"cricket\", \"cricket\"]"
                                        ]
                                }
                        }
                },
                "rejectedPlans" : [ ]
        },
        "serverInfo" : {
                "host" : "LAPTOP-MDE57TIS",
                "port" : 27017,
                "version" : "4.0.10",
                "gitVersion" : "c389e7f69f637f7a1ac3cc9fae843b635f20b766"
        },
        "ok" : 1
}

若運(yùn)行結(jié)果中存在 "cursor":"BtreeCursor tags_1" 則說明查詢中正確使用了索引。

索引子文檔字段

假設(shè)我們要根據(jù) address 子文檔的 city、country、postcode 等字段來搜索文檔,由于所有這些字段都是 address 子文檔的一部分,所以我們需要為子文檔上的所有字段創(chuàng)建索引。

要在子文檔的所有三個字段上創(chuàng)建索引,可以使用如下所示的代碼:

> db.users.ensureIndex({"address.city":1,"address.country":1,"address.postcode":1})
{
        "createdCollectionAutomatically" : false,
        "numIndexesBefore" : 3,
        "numIndexesAfter" : 4,
        "ok" : 1
}

索引創(chuàng)建成功后,我們就可以使用 address 子文檔中的任何字段來搜索集合中的數(shù)據(jù)了,如下所示:

> db.users.find({"address.city":"Hebei"}).pretty()
{
        "_id" : ObjectId("603f571d5e514debed504a39"),
        "address" : {
                "city" : "Hebei",
                "country" : "China",
                "postcode" : "000000"
        },
        "tags" : [
                "music",
                "cricket",
                "blogs"
        ],
        "name" : "bianchengbang"
}

另外,在查詢時也可以設(shè)置多個查詢條件,如下所示:

> db.users.find({"address.city":"Hebei", "address.country":"China"}).pretty()
{
        "_id" : ObjectId("603f571d5e514debed504a39"),
        "address" : {
                "city" : "Hebei",
                "country" : "China",
                "postcode" : "000000"
        },
        "tags" : [
                "music",
                "cricket",
                "blogs"
        ],
        "name" : "bianchengbang"
}

網(wǎng)站標(biāo)題:MongoDB高級索引
地址分享:http://m.5511xx.com/article/cocpdsj.html