複数ドキュメントの検索
collection.find()
を使用して、コレクション内の複数のドキュメントをクエリできます。 find()
メソッドは、指定したクエリ ドキュメントを使用して、クエリに一致するコレクション内のドキュメントのサブセットを照合します。 クエリ ドキュメントを指定しなかった場合 (あるいは空のドキュメントを指定した場合)、 MongoDB はコレクション内のすべてのドキュメントを返します。 MongoDB のクエリの詳細については、 クエリ ドキュメントに関するドキュメントを参照してください。
結果セットを構成するために、並べ替えやプロジェクションなどの追加のクエリ オプションを定義することもできます。これらは、 sort
およびprojection
オブジェクトのfind()
メソッド呼び出しのオプション パラメータで指定できます。メソッドに渡すことができるパラメータの詳細については、collection.find() を参照してください。
find()
メソッドは、クエリの結果を管理する FindCursor を返します。for await...of
構文または以下のカーソルメソッドのいずれかを使用して、一致するドキュメントを繰り返し処理できます。
next()
toArray()
クエリに一致するドキュメントがない場合、 find()
では空のカーソルが返されます。
互換性
Node.js ドライバーを使用して接続し、次の環境でホストされている配置にfind()
メソッドを使用できます。
MongoDB Atlas はクラウドでの MongoDB 配置のためのフルマネージド サービスです
MongoDB Enterprise: サブスクリプションベースの自己管理型 MongoDB バージョン
MongoDB Community: ソースが利用可能で、無料で使用できる、MongoDB の自己管理型バージョン
MongoDB Atlas でホストされている配置の Atlas UI でドキュメントを検索する方法の詳細については、「ドキュメントの作成、表示、更新、および削除」を参照してください。
例
次のスニペットは、 movies
コレクションからドキュメントを検索します。次のパラメータを使用します。
長さが 15 分未満の映画のみを返すクエリを設定するクエリドキュメント。
返されたドキュメントをタイトルの昇順に(アルファベット順で、" A " が " Z " の前に、" 1 " が " 9 " の前に来るように)並べ替えるソート。
返されるドキュメントから
_id
フィールドを明示的に除外し、title
とimdb
オブジェクト(およびその埋め込みフィールド)のみを明示的に含むプロジェクション。
注意
この例を使って MongoDB のインスタンスに接続し、サンプルデータを含むデータベースとやり取りできます。MongoDB インスタンスへの接続とサンプル データセットの読み込みの詳細については、使用例ガイドを参照してください。
1 import { MongoClient } from "mongodb"; 2 3 // Replace the uri string with your MongoDB deployment's connection string. 4 const uri = "<connection string uri>"; 5 6 const client = new MongoClient(uri); 7 8 async function run() { 9 try { 10 11 // Get the database and collection on which to run the operation 12 const database = client.db("sample_mflix"); 13 const movies = database.collection("movies"); 14 15 // Query for movies that have a runtime less than 15 minutes 16 const query = { runtime: { $lt: 15 } }; 17 18 const options = { 19 // Sort returned documents in ascending order by title (A->Z) 20 sort: { title: 1 }, 21 // Include only the `title` and `imdb` fields in each returned document 22 projection: { _id: 0, title: 1, imdb: 1 }, 23 }; 24 25 // Execute query 26 const cursor = movies.find(query, options); 27 28 // Print a message if no documents were found 29 if ((await movies.countDocuments(query)) === 0) { 30 console.log("No documents found!"); 31 } 32 33 // Print returned documents 34 for await (const doc of cursor) { 35 console.dir(doc); 36 } 37 38 } finally { 39 await client.close(); 40 } 41 } 42 run().catch(console.dir);
1 import { MongoClient } from "mongodb"; 2 3 // Replace the uri string with your MongoDB deployment's connection string. 4 const uri = "<connection string uri>"; 5 6 const client = new MongoClient(uri); 7 8 type Minutes = number; 9 10 interface IMDB { 11 rating: number; 12 votes: number; 13 id: number; 14 } 15 16 interface Movie { 17 title: string; 18 imdb: IMDB; 19 runtime: Minutes; 20 } 21 22 async function run() { 23 try { 24 const database = client.db("sample_mflix"); 25 const movies = database.collection<Movie>("movies"); 26 27 const query = { runtime: { $lt: 15 } }; 28 const cursor = movies.find<Movie>( 29 query, 30 { 31 sort: { title: 1 }, 32 projection: { _id: 0, title: 1, imdb: 1 }, 33 } 34 ); 35 36 if ((await movies.countDocuments(query)) === 0) { 37 console.warn("No documents found!"); 38 } 39 40 for await (const doc of cursor) { 41 console.dir(doc); 42 } 43 } finally { 44 await client.close(); 45 } 46 } 47 run().catch(console.dir);
前の例を実行すると、次の出力が表示されます。
{ title: '10 Minutes', imdb: { rating: 7.9, votes: 743, id: 339976 } } { title: '3x3', imdb: { rating: 6.9, votes: 206, id: 1654725 } } { title: '7:35 in the Morning', imdb: { rating: 7.3, votes: 1555, id: 406501 } } { title: '8', imdb: { rating: 7.8, votes: 883, id: 1592502 } } ...
sort
オプションと projection
オプションは、find()
メソッドに連結されたメソッド(sort()
と project()
)として指定することもできます。次の 2 つのコマンドは同等です。
movies.find({ runtime: { $lt: 15 } }, { sort: { title: 1 }, projection: { _id: 0, title: 1, imdb: 1 }}); movies.find({ runtime: { $lt: 15 } }).sort({ title: 1}).project({ _id: 0, title: 1, imdb: 1 });