MongoDB聚合运算符:$slice

发布于:2024-05-01 ⋅ 阅读:(29) ⋅ 点赞:(0)

MongoDB聚合运算符:$slice


$slice聚合运算符返回数组的子集。

语法

$slice有两种使用语法:

  1. 从数组的开头或结尾返回元素:

    { $slice: [ <array>, <n> ] }
    
  2. 从数组中的指定位置返回元素:

    { $slice: [ <array>, <position>, <n> ] }
    

参数说明

  • <array>:可以解析为数组的任何表达式。
  • <position>:可选参数,整数表达式。
    • 如果<position>为正,表示以数组首部作为起始位置,如果<position>大于元素数量,则$slice返回空数组。
    • 如果<position>为负,表示以数组尾部作为起始位置,如果<position>的绝对值大于元素数量,则起始位置为数组的首部。
  • <n>为可解析为正整数的表达式:
    • 如果为正,$slice返回数组中的前 n 个元素。如果指定了 <position>,则 $slice 返回从该位置开始的前 n 个元素。
    • 如果为负数,$slice 返回数组中的最后 n 个元素。如果指定了 <position>,则 n 不能为负数。

使用

举例 结果
{ $slice: [ [ 1, 2, 3 ], 1, 1 ] } [ 2 ]
{ $slice: [ [ 1, 2, 3 ], -2 ] } [ 2, 3 ]
{ $slice: [ [ 1, 2, 3 ], 15, 2 ] } [ ]
{ $slice: [ [ 1, 2, 3 ], -15, 2 ] } [ 1, 2 ]

举例

users集合有下列文档:

{ "_id" : 1, "name" : "dave123", favorites: [ "chocolate", "cake", "butter", "apples" ] }
{ "_id" : 2, "name" : "li", favorites: [ "apples", "pudding", "pie" ] }
{ "_id" : 3, "name" : "ahn", favorites: [ "pears", "pecans", "chocolate", "cherries" ] }
{ "_id" : 4, "name" : "ty", favorites: [ "ice cream" ] }

下面的示例返回用户收藏夹favorites数组中的前三个元素:

db.users.aggregate([
   { $project: { name: 1, threeFavorites: { $slice: [ "$favorites", 3 ] } } }
])

操作返回下面的结果:

{ "_id" : 1, "name" : "dave123", "threeFavorites" : [ "chocolate", "cake", "butter" ] }
{ "_id" : 2, "name" : "li", "threeFavorites" : [ "apples", "pudding", "pie" ] }
{ "_id" : 3, "name" : "ahn", "threeFavorites" : [ "pears", "pecans", "chocolate" ] }
{ "_id" : 4, "name" : "ty", "threeFavorites" : [ "ice cream" ] }

网站公告

今日签到

点亮在社区的每一天
去签到