$slice
$slice
$slice
수정자는$push
작업 중 배열 요소의 수를 제한합니다. 읽기 작업에서 지정된 수의 배열 요소를 프로젝트 하거나 반환하려면$slice
프로젝션 연산자 를 대신 참조하세요.$slice
수정자를 사용하려면$each
수정자와 함께 표시되어야 합니다. 빈 배열[]
을$each
수정자에 전달하여$slice
수정자만 효과를 갖도록 할 수 있습니다.{ $push: { <field>: { $each: [ <value1>, <value2>, ... ], $slice: <num> } } } <num>
은 다음과 같을 수 있습니다.값설명Zero배열<field>
를 빈 배열로 업데이트합니다.음수마지막<num>
요소만 포함하도록<field>
배열을 업데이트합니다.양수배열<field>
에 처음<num>
요소만 포함하도록 업데이트합니다.
행동
MongoDB 5.0부터 업데이트 연산자는 문자열 기반 이름이 있는 문서 필드를 사전순으로 처리합니다. 숫자 이름이 있는 필드는 숫자 순서대로 처리됩니다. 자세한 내용은 업데이트 운영자 동작을 참조하십시오.
수정자가 표시되는 순서는 중요하지 않습니다. 이전 버전에서는 $slice
와 함께 사용되는 경우 $each
수정자가 첫 번째 수정자로 표시되어야 했습니다. $push
에 사용할 수 있는 수정자 목록은 수정자에서 확인하세요.
예시
배열 끝에서 슬라이스
컬렉션 students
에는 다음 문서가 포함되어 있습니다.
{ "_id" : 1, "scores" : [ 40, 50, 60 ] }
다음 작업은 scores
배열에 새 요소를 추가한 다음 $slice
수정자를 사용하여 배열을 마지막 5개의 요소로 슬라이스합니다.
db.students.updateOne( { _id: 1 }, { $push: { scores: { $each: [ 80, 78, 86 ], $slice: -5 } } } )
작업 결과는 업데이트된 scores
배열의 요소를 마지막 5개 요소로 슬라이스하는 것입니다.
{ "_id" : 1, "scores" : [ 50, 60, 80, 78, 86 ] }
배열 앞에서 슬라이스
컬렉션 students
에는 다음 문서가 포함되어 있습니다.
{ "_id" : 2, "scores" : [ 89, 90 ] }
다음 작업은 scores
배열에 새 요소를 추가한 다음 $slice
수정자를 사용하여 배열 처음에 있는 요소 세 개에서 자릅니다.
db.students.updateOne( { _id: 2 }, { $push: { scores: { $each: [ 100, 20 ], $slice: 3 } } } )
작업 결과는 업데이트된 scores
배열의 요소를 처음 3개 요소로 슬라이스하는 것입니다.
{ "_id" : 2, "scores" : [ 89, 90, 100 ] }
슬라이스만 사용하여 배열 업데이트
컬렉션 students
에는 다음 문서가 포함되어 있습니다.
{ "_id" : 3, "scores" : [ 89, 70, 100, 20 ] }
$slice
수정자의 효과만 사용하여 scores
필드를 업데이트하려면 $slice
수정자에 대해 슬라이스할 요소의 수(예: -3
) 및 $each
수정자에 대해 빈 배열 []
를 다음과 같이 지정합니다.
db.students.updateOne( { _id: 3 }, { $push: { scores: { $each: [ ], $slice: -3 } } } )
작업 결과는 scores
배열의 요소를 마지막 3개 요소로 슬라이스하는 것입니다.
{ "_id" : 3, "scores" : [ 70, 100, 20 ] }
$slice
다른 $push
수정자와 함께 사용
다음 문서를 students
컬렉션에 추가합니다:
db.students.insertOne( { "_id" : 5, "quizzes" : [ { "wk": 1, "score" : 10 }, { "wk": 2, "score" : 8 }, { "wk": 3, "score" : 5 }, { "wk": 4, "score" : 6 } ] } )
다음 $push
작업에서는 다음을 사용합니다.
quizzes
배열에 여러 문서를 추가하는$each
수정자,수정된
quizzes
배열의 모든 요소를score
필드를 기준으로 내림차순으로 정렬하는$sort
수정자, 그리고quizzes
배열의 처음 3개의 정렬된 요소만 유지하기 위해 사용하는$slice
수정자입니다.
db.students.updateOne( { _id: 5 }, { $push: { quizzes: { $each: [ { wk: 5, score: 8 }, { wk: 6, score: 7 }, { wk: 7, score: 6 } ], $sort: { score: -1 }, $slice: 3 } } } )
작업 후에는 가장 높은 점수를 받은 세 개의 퀴즈만 배열에 표시됩니다:
{ "_id" : 5, "quizzes" : [ { "wk" : 1, "score" : 10 }, { "wk" : 2, "score" : 8 }, { "wk" : 5, "score" : 8 } ] }
수정자의 순서는 수정자가 처리되는 순서에 중요하지 않습니다. 자세한 내용은 수정자를 참조하세요.