MongoDB
 Computer >> コンピューター >  >> プログラミング >> MongoDB

MongoDB 3.xで重複レコードを削除するにはどうすればよいですか?


重複するレコードを削除するには、aggregate()を使用します。ドキュメントを使用してコレクションを作成しましょう-

> db.demo438.insertOne({"FirstName":"Chris"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e775c37bbc41e36cc3caea1")
}
> db.demo438.insertOne({"FirstName":"David"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e775c3dbbc41e36cc3caea2")
}
> db.demo438.insertOne({"FirstName":"Chris"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e775c40bbc41e36cc3caea3")
}
> db.demo438.insertOne({"FirstName":"Bob"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e775c44bbc41e36cc3caea4")
}
> db.demo438.insertOne({"FirstName":"David"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e775c47bbc41e36cc3caea5")
}

find()メソッドを使用してコレクションからすべてのドキュメントを表示する-

> db.demo438.find();

これにより、次の出力が生成されます-

{ "_id" : ObjectId("5e775c37bbc41e36cc3caea1"), "FirstName" : "Chris" }
{ "_id" : ObjectId("5e775c3dbbc41e36cc3caea2"), "FirstName" : "David" }
{ "_id" : ObjectId("5e775c40bbc41e36cc3caea3"), "FirstName" : "Chris" }
{ "_id" : ObjectId("5e775c44bbc41e36cc3caea4"), "FirstName" : "Bob" }
{ "_id" : ObjectId("5e775c47bbc41e36cc3caea5"), "FirstName" : "David" }

以下は、MongoDB3.xで重複レコードを削除するためのクエリです-

> db.demo438.aggregate([ { "$group":{ _id:{FirstName:"$FirstName"}, DuplicateValueIds:{$addToSet:"$_id"} } } ]);

これにより、次の出力が生成されます-

{ "_id" : { "FirstName" : "David" }, "DuplicateValueIds" : [ ObjectId("5e775c47bbc41e36cc3caea5"), ObjectId("5e775c3dbbc41e36cc3caea2") ] }
{ "_id" : { "FirstName" : "Bob" }, "DuplicateValueIds" : [ ObjectId("5e775c44bbc41e36cc3caea4") ] }
{ "_id" : { "FirstName" : "Chris" }, "DuplicateValueIds" : [ ObjectId("5e775c40bbc41e36cc3caea3"), ObjectId("5e775c37bbc41e36cc3caea1") ] }

  1. Google ドライブの重複ファイルを削除する方法

    Google Drive や One Drive などのクラウド ストレージ サービスを定期的に使用している場合、重複ファイルは脅威となる可能性があります。 Google ドライブを使用すると、携帯電話、タブレット、パソコンなど、あらゆるデバイスからファイルを保存、アップロード、アクセス、変更できます。スペースが限られているため、ファイルが重複するとストレージ容量がさらに減少する可能性があります。特に多数のデバイス間での同期が関係している場合、ファイルの複製が時々発生します。ただし、多数のファイルがある場合、これらの重複を見つけるのは難しく、時間がかかる場合があります。今日は、Google ド

  2. Excel で重複行を見つけて削除する方法

    Excel の非常に一般的な用途の 1 つは、データをクリーンアップするためのツールとして使用されることです。データのクリーンアップとは: 生データをワークシートに取り込む さまざまな要件に準拠するようにデータを操作する 要約すると、適切に分析できるようにデータがクリーンアップされます。 データは非常に多くの異なる角度からクリーンアップされます。それらのテクニックを1つずつ説明します。この投稿では、重複行の削除のみに分析を限定します . Excel で重複行を削除する 理由が何であれ、データに重複する行が含まれる場合があります。ほとんどの場合、重複する行を削除する必要があります。昔は