翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。
$slice
$slice 集計演算子を使用すると、配列の先頭または末尾から配列を横断して、配列のサブセットを返すことができます。これは、上位 N 項目や下位 N 項目など、配列フィールドから限られた数の項目を表示するために使用されます。
パラメータ
-
array: スライスする配列フィールド。 -
n: 返す要素の数を指定する整数。正の値は配列の先頭から始まり、負の値は配列の末尾から始まります。
例 (MongoDB シェル)
次の例は、 $sliceを使用して各シェフの最初の 2 つのお気に入りのお菓子を返す方法を示しています。
サンプルドキュメントを作成する
db.sweets.insertMany([ { "_id" : 1, "name" : "Alvin", "favorites": [ "chocolate", "cake", "toffee", "beignets" ] }, { "_id" : 2, "name" : "Tom", "favorites": [ "donuts", "pudding", "pie" ] }, { "_id" : 3, "name" : "Jessica", "favorites": [ "fudge", "smores", "pudding", "cupcakes" ] }, { "_id" : 4, "name" : "Rachel", "favorites": [ "ice cream" ] } ]);
クエリの例
db.sweets.aggregate([ { $project: { _id: 0, name: 1, topTwoFavorites: { $slice: [ "$favorites", 2 ] } } } ]);
出力
[
{ name: 'Alvin', topTwoFavorites: [ 'chocolate', 'cake' ] },
{ name: 'Tom', topTwoFavorites: [ 'donuts', 'pudding' ] },
{ name: 'Jessica', topTwoFavorites: [ 'fudge', 'smores' ] },
{ name: 'Rachel', topTwoFavorites: [ 'ice cream' ] }
]
この例では、 $slice演算子を使用して、各ドキュメントのfavorites配列から最初の 2 つの要素を抽出します。
コードの例
$slice コマンドを使用するコード例を表示するには、使用する言語のタブを選択します。