Computer >> 컴퓨터 >  >> 프로그램 작성 >> MongoDB

MongoDB에서 부분 데이터를 삭제하시겠습니까?

<시간/>

이를 위해 map()을 사용할 수 있습니다. 먼저 문서로 컬렉션을 생성해 보겠습니다. −

> db.deleteDemo.insertOne({"Name":"John"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd550492cba06f46efe9f06")
}
> db.deleteDemo.insertOne({"Name":"Carol"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd5504d2cba06f46efe9f07")
}
> db.deleteDemo.insertOne({"Name":"Sam"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd550512cba06f46efe9f08")
}
> db.deleteDemo.insertOne({"Name":"David"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd5505d2cba06f46efe9f09")
}
> db.deleteDemo.insertOne({"Name":"Robert"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd550682cba06f46efe9f0a")
}
> db.deleteDemo.insertOne({"Name":"Chris"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd5506f2cba06f46efe9f0b")
}
> db.deleteDemo.insertOne({"Name":"Mike"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd550752cba06f46efe9f0c")
}
> db.deleteDemo.insertOne({"Name":"Bob"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd5507a2cba06f46efe9f0d")
}
> db.deleteDemo.insertOne({"Name":"James"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd550822cba06f46efe9f0e")
}
> db.deleteDemo.insertOne({"Name":"Jace"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cd550862cba06f46efe9f0f")
}

다음은 find() 메서드를 사용하여 컬렉션의 모든 문서를 표시하는 쿼리입니다. -

> db.deleteDemo.find();

이것은 다음과 같은 출력을 생성합니다 -

{ "_id" : ObjectId("5cd550492cba06f46efe9f06"), "Name" : "John" }
{ "_id" : ObjectId("5cd5504d2cba06f46efe9f07"), "Name" : "Carol" }
{ "_id" : ObjectId("5cd550512cba06f46efe9f08"), "Name" : "Sam" }
{ "_id" : ObjectId("5cd5505d2cba06f46efe9f09"), "Name" : "David" }
{ "_id" : ObjectId("5cd550682cba06f46efe9f0a"), "Name" : "Robert" }
{ "_id" : ObjectId("5cd5506f2cba06f46efe9f0b"), "Name" : "Chris" }
{ "_id" : ObjectId("5cd550752cba06f46efe9f0c"), "Name" : "Mike" }
{ "_id" : ObjectId("5cd5507a2cba06f46efe9f0d"), "Name" : "Bob" }
{ "_id" : ObjectId("5cd550822cba06f46efe9f0e"), "Name" : "James" }
{ "_id" : ObjectId("5cd550862cba06f46efe9f0f"), "Name" : "Jace" }

다음은 MongoDB에서 부분 데이터를 삭제하는 쿼리입니다 -

> var value = db.deleteDemo.find({}, {_id : 1}).skip(5).toArray().map(function(documentValue) { return documentValue._id; });
> db.deleteDemo.remove({_id: {$in:value}});
WriteResult({ "nRemoved" : 5 })

위의 쿼리는 5번째 레코드 이후의 모든 문서를 삭제합니다. 위 컬렉션의 모든 문서를 표시합니다 -

> db.deleteDemo.find();

이것은 다음과 같은 출력을 생성합니다 -

{ "_id" : ObjectId("5cd550492cba06f46efe9f06"), "Name" : "John" }
{ "_id" : ObjectId("5cd5504d2cba06f46efe9f07"), "Name" : "Carol" }
{ "_id" : ObjectId("5cd550512cba06f46efe9f08"), "Name" : "Sam" }
{ "_id" : ObjectId("5cd5505d2cba06f46efe9f09"), "Name" : "David" }
{ "_id" : ObjectId("5cd550682cba06f46efe9f0a"), "Name" : "Robert" }