溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MongoDB中find操作符怎么使用

發(fā)布時(shí)間:2023-04-21 14:20:55 來(lái)源:億速云 閱讀:148 作者:iii 欄目:開發(fā)技術(shù)

這篇“MongoDB中find操作符怎么使用”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“MongoDB中find操作符怎么使用”文章吧。

數(shù)據(jù)庫(kù)初始化

在我們繼續(xù)執(zhí)行查找操作之前,我們首先需要設(shè)置一個(gè)數(shù)據(jù)庫(kù)baeldung和一個(gè)樣本收集員工:

db.employee.insertMany([
{
    "employeeId":"EMP1",
    "name":"Sam", 
    "age":23,
    "type":"Full Time",
    "department":"Engineering"
},
{ 
    "employeeId":"EMP2",
    "name":"Tony",
    "age":31,
    "type":"Full Time",
    "department":"Admin"
},
{
    "employeeId":"EMP3",
    "name":"Lisa",
    "age":42,
    "type":"Part Time",
    "department":"Engineering"
}]);

成功插入后,上述查詢將返回類似于下圖所示的 JSON 結(jié)果:

{
    "acknowledged" : true,
    "insertedIds" : [
        ObjectId("62a88223ff0a77909323a7fa"),
        ObjectId("62a88223ff0a77909323a7fb"),
        ObjectId("62a88223ff0a77909323a7fc")
    ]
}

此時(shí),我們已將一些文檔插入到我們的集合中以執(zhí)行各種類型的查找操作。

使用 MongoDB Shell

要從 MongoDB 集合中查詢文檔,我們使用 db.collection.find(query, projection) 方法。該方法接受兩個(gè)可選參數(shù)— 查詢(query) 和 投影(projection) —作為 MongoDB BSON文檔。

查詢參數(shù)接受帶有查詢運(yùn)算符的選擇過(guò)濾器。要從 MongoDB 集合中檢索所有文檔,我們可以省略此參數(shù)或傳遞一個(gè)空白文檔。

接下來(lái),投影參數(shù)用于指定要從匹配文檔返回的字段。要返回匹配文檔中的所有字段,我們可以省略此參數(shù)。

此外,讓我們從返回所有集合文檔的基本查找查詢開始:

db.employee.find({});

上面的查詢將返回員工集合中的所有文檔:

{ "_id" : ObjectId("62a88223ff0a77909323a7fa"), "employeeId" : "1", "name" : "Sam", "age" : 23, "type" : "Full Time", "department" : "Engineering" }{ "_id" : ObjectId("62a88223ff0a77909323a7fb"), "employeeId" : "2", "name" : "Tony", "age" : 31, "type" : "Full Time", "department" : "Admin" }{ "_id" : ObjectId("62a88223ff0a77909323a7fc"), "employeeId" : "3", "name" : "Ray", "age" : 42, "type" : "Part Time", "department" : "Engineering" }

*接下來(lái),讓我們編寫一個(gè)查詢來(lái)返回屬于“Engineering” *部門的所有員工:

db.employee.find({    "department":"Engineering"});

上述查詢返回部門等于 “Engineering”的所有員工收款單據(jù):

{ "_id" : ObjectId("62a88223ff0a77909323a7fa"), "employeeId" : "1", "name" : "Sam", "age" : 23, "type" : "Full Time", "department" : "Engineering" }{ "_id" : ObjectId("62a88223ff0a77909323a7fc"), "employeeId" : "3", "name" : "Ray", "age" : 42, "type" : "Part Time", "department" : "Engineering" }

最后,讓我們編寫一個(gè)查詢來(lái)獲取屬于“Engineering”部門的所有員工的 姓名 和 年齡:

db.employee.find({    "department":"Engineering"},{    "name":1,    "age":1});

上述查詢只返回符合查詢條件的文檔的名稱和年齡字段:

{ "_id" : ObjectId("62a88223ff0a77909323a7fa"), "name" : "Sam", "age" : 23 }{ "_id" : ObjectId("62a88223ff0a77909323a7fc"), "name" : "Ray", "age" : 42 }

請(qǐng)注意,除非明確排除,否則所有文檔中默認(rèn)返回_id字段。

此外,重要的是要注意 find 運(yùn)算符將光標(biāo)返回到與查詢過(guò)濾器匹配的文檔。MongoDB Shell 自動(dòng)迭代光標(biāo)以顯示多達(dá) 20 個(gè)文檔。

此外,MongoDB Shell 提供了一個(gè)*findOne()*方法,該方法只返回一個(gè)滿足上述查詢條件的文檔。如果多個(gè)文檔匹配,則將按照磁盤上文檔的自然順序返回第一個(gè)文檔:

db.employee.findOne();

與*find()*不同,上面的查詢將只返回一個(gè)文檔而不是游標(biāo):

{    "_id" : ObjectId("62a99e22a849e1472c440bbf"),    "employeeId" : "EMP1",    "name" : "Sam",    "age" : 23,    "type" : "Full Time",    "department" : "Engineering"}

4. 使用 Java 驅(qū)動(dòng)程序

到目前為止,我們已經(jīng)了解了如何使用 MongoDB Shell 來(lái)執(zhí)行查找操作。接下來(lái),讓我們使用 MongoDB Java 驅(qū)動(dòng)程序?qū)崿F(xiàn)相同的功能。在開始之前,讓我們先創(chuàng)建一個(gè)到員工集合的MongoClient連接:

MongoClient mongoClient = new MongoClient("localhost", 27017);MongoDatabase database = mongoClient.getDatabase("baeldung");MongoCollection<Document> collection = database.getCollection("employee");

在這里,我們創(chuàng)建了到運(yùn)行在默認(rèn)端口 27017 上的 MongoDB 服務(wù)器的連接。接下來(lái),我們從連接創(chuàng)建的*MongoDatabase實(shí)例中獲取MongoCollection的實(shí)例。

首先,要執(zhí)行*查找操作,我們?cè)贛ongoCollection的實(shí)例上調(diào)用 find() 方法。讓我們檢查代碼以從集合中檢索所有文檔:

FindIterable<Document> documents = collection.find();MongoCursor<Document> cursor = documents.iterator();while (cursor.hasNext()) {    System.out.println(cursor.next());}

請(qǐng)注意,find()方法返回FindIterable<Document>的一個(gè)實(shí)例。然后我們通過(guò)調(diào)用 FindIterable 的iterator()方法獲得MongoCursor的一個(gè)實(shí)例。最后,我們遍歷光標(biāo)以檢索每個(gè)文檔。

接下來(lái),讓我們添加查詢運(yùn)算符來(lái)過(guò)濾從查找操作返回的文檔:

Bson filter = Filters.eq("department", "Engineering");FindIterable<Document> documents = collection.find(filter);MongoCursor<Document> cursor = documents.iterator();while (cursor.hasNext()) {    System.out.println(cursor.next());}

在這里,我們將Bson過(guò)濾器作為參數(shù)傳遞給find()方法。我們可以使用查詢運(yùn)算符的任意組合作為find()方法的過(guò)濾器。上面的代碼片段將返回department 等于“Engineering”的所有文檔。

此外,讓我們編寫一個(gè)片段,它只返回匹配選擇條件的文檔中的姓名和年齡字段:

Bson filter = Filters.eq("department", "Engineering");Bson projection = Projections.fields(Projections.include("name", "age"));FindIterable<Document> documents = collection.find(filter)  .projection(projection);MongoCursor<Document> cursor = documents.iterator();while (cursor.hasNext()) {    System.out.println(cursor.next());}

在這里,我們調(diào)用FindIterable實(shí)例的projection()方法。我們將Bson過(guò)濾器作為參數(shù)傳遞給*projection()*方法。我們可以使用投影操作在最終結(jié)果中包含或排除任何字段。

最后,我們可以使用FindIterable實(shí)例上的first()方法檢索結(jié)果的第一個(gè)文檔。這將返回單個(gè)文檔而不是MongoCursor實(shí)例:

FindIterable<Document> documents = collection.find();Document document = documents.first();

以上就是關(guān)于“MongoDB中find操作符怎么使用”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI