$in$in演算子は、フィールドの値が指定された配列内の任意の値と等しいドキュメントを選択します。
互換性
次の環境でホストされる配置には $in を使用できます。
MongoDB Atlas はクラウドでの MongoDB 配置のためのフルマネージド サービスです
MongoDB Enterprise: サブスクリプションベースの自己管理型 MongoDB バージョン
MongoDB Community: ソースが利用可能で、無料で使用できる自己管理型の MongoDB のバージョン
構文
$in 演算子は次の形式をとります。
{ field: { $in: [ <value1>, <value2>, ... <valueN> ] } }
異なる BSON 型値の比較については、BSON 比較順序の指定を参照してください。
fieldに配列がある場合、$in 演算子は、field に指定された配列内の値と一致する要素が少なくとも 1<value1> つ含まれる配列があるドキュメントを選択します。例、、、<value2> 、 など。
$in は各パラメータをコレクション内の各ドキュメントと比較するため、パフォーマンスの問題が発生する可能性があります。パフォーマンスを向上させるには:
$inに渡されるパラメータの数を数十の値に制限します。数百のパラメーターを使用すると、クエリのパフォーマンスに悪影響を影響可能性があります。クエリを実行したい
fieldにインデックスを作成します。
Atlas Search を使用した Atlas 上のデータのクエリ
MongoDB Atlas に保存されているデータには、Atlas Search の in Operator 演算子を $search クエリを実行中に使用できます。$inを$searchの後に実行する場合、$searchを in Operator 演算子を使用して実行するよりもパフォーマンスが低下します。
この演算子の Atlas Search バージョンの詳細については、Atlas ドキュメントの in 演算子 を参照してください。
例
例で使用されている inventoryコレクションを作成するには、次のコマンドを実行します。
db.inventory.insertMany( [ { item: "Pens", quantity: 350, tags: [ "school", "office" ] }, { item: "Erasers", quantity: 15, tags: [ "school", "home" ] }, { item: "Maps", tags: [ "office", "storage" ] }, { item: "Books", quantity: 5, tags: [ "school", "storage", "home" ] } ] )
Match Values
このクエリは、quantityフィールドの値が 5 または 15 である inventoryコレクション内のドキュメントを選択します。
db.inventory.find( { quantity: { $in: [ 5, 15 ] } }, { _id: 0 } )
出力:
{ item: 'Erasers', quantity: 15, tags: [ 'school', 'home' ] }, { item: 'Books', quantity: 5, tags: [ 'school', 'storage', 'home' ] }
演算子を使用してクエリを作成できますが、同じフィールドで等価性チェックを実行する場合は、$or $in演算子ではなく$or 演算子を使用します。
配列内の値に一致
次のupdateMany() 操作は、exclude falsetags配列に"home" または のいずれかに一致する要素が 1 つ以上ある場合に、 フィールドを"school" に設定します。
db.inventory.updateMany( { tags: { $in: [ "home", "school" ] } }, { $set: { exclude: false } } )
出力例:
{ item: 'Pens', quantity: 350, tags: [ 'school', 'office' ], exclude: false }, { item: 'Erasers', quantity: 15, tags: [ 'school', 'home' ], exclude: false }, { item: 'Books', quantity: 5, tags: [ 'school', 'storage', 'home' ], exclude: false }
配列のクエリに関するその他の例えは、以下を参照してください。
クエリに関するその他の例えについては、「ドキュメントのクエリ 」を参照してください。
$in正規表現と の使用
$in演算子は、/pattern/ 形式の正規表現を使用してドキュメントを選択できます。$regex $in内では 式は使用できません。
このクエリは、tagsフィールドがbe または st で始まる inventoryコレクション内のドキュメントを選択します。
db.inventory.find( { tags: { $in: [ /^be/, /^st/ ] } } )
このクエリは、tagsフィールドに be または st で始まる string または、be または st で始まる要素が 1 つ以上ある配列がある inventoryコレクション内のすべてのドキュメントを選択します。