MongoDB find()は再帰検索を操作しますか?
再帰検索を実行するには、ドット表記でfind()を使用します。まず、ドキュメントを使用してコレクションを作成しましょう-
> db.findOperationDemo.insertOne({"ClientDetails":[{"ClientId":101,"ClientName":"Chris"},{"ClientId":102,"ClientName":"Robert"}]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cd9a118b50a6c6dd317ad99")
}
> db.findOperationDemo.insertOne({"ClientDetails":[{"ClientId":110,"ClientName":"David"},{"ClientId":112,"ClientName":"Mike"}]});
{
"acknowledged" : true,
"insertedId" : ObjectId("5cd9a12fb50a6c6dd317ad9a")
} 以下は、find()メソッドを使用してコレクションからすべてのドキュメントを表示するためのクエリです-
> db.findOperationDemo.find().pretty();
これにより、次の出力が生成されます-
{
"_id" : ObjectId("5cd9a118b50a6c6dd317ad99"),
"ClientDetails" : [
{
"ClientId" : 101,
"ClientName" : "Chris"
},
{
"ClientId" : 102,
"ClientName" : "Robert"
}
]
}
{
"_id" : ObjectId("5cd9a12fb50a6c6dd317ad9a"),
"ClientDetails" : [
{
"ClientId" : 110,
"ClientName" : "David"
},
{
"ClientId" : 112,
"ClientName" : "Mike"
}
]
} 以下は、ドット表記を使用した再帰検索のfind()を実装するためのクエリです-
> db.findOperationDemo.find({"ClientDetails.ClientId":110}); これにより、次の出力が生成されます-
{ "_id" : ObjectId("5cd9a12fb50a6c6dd317ad9a"), "ClientDetails" : [ { "ClientId" : 110, "ClientName" : "David" }, { "ClientId" : 112, "ClientName" : "Mike" } ] } -
MongoDBでオブジェクトの配列を検索できますか?
はい、オブジェクトの配列を検索するには、MongoDBaggregate()で$unwindを使用します。一致させるには、$matchを使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo623.insertOne( ... { ... _id:1, ... details:[ ... { ...
-
MongoDB全文検索を実行します
MongoDBでの全文検索には、$textを使用します。 $ textは、フィールドのコンテンツに対してテキスト検索を実行します。ドキュメントを使用してコレクションを作成しましょう- > db.demo654.createIndex({Name:"text"}); { "createdCollectionAutomatically" : true, "numIndexesBefore" : 1, "numIndexesAfter"