web-dev-qa-db-ja.com

MongoDB .Netドライバー2.0プル(要素の削除)

2.0ドライバーで「プル(削除)」を正しく実行するのを手伝ってくれませんか。

このようなコレクションがあり、followerフィールドでfethiyeという名前の最初のフォロワーを削除します。

{
  "_id": ObjectId("554e05dfc90d3d4dfcaa2aea"),
  "username": "bodrum",
  "followerList": [
    {
      "_id": ObjectId("554e0625a51586362c33c6df"),
      "follower": "fethiye",
      "avatar": "fethiye.png"
    },
    {
      "_id": ObjectId("554e0625a51586362c33c6df"),
      "follower": "izmir",
      "avatar": "izmir.png"
    }
  ]
} 

このクエリを修正するにはどうすればよいですか?

var filter = new BsonDocument("username", "bodrum");
var update = Builders<Person>.Update.Pull("followerList:follower", "fethiye");
Person pr = collection.FindOneAndUpdateAsync(filter, update).Result;

ありがとう。

14
fatihyildizhan

フィルターを使用して配列要素を削除する場合は、PullFilter(要素全体に一致)の代わりに Pull ビルダーを使用する必要があります。

var collection = db.GetCollection<Person>("people");
var filter = new BsonDocument("username", "bodrum");
var update = Builders<Person>.Update.PullFilter("followerList",
    Builders<Follower>.Filter.Eq("follower", "fethiye"));
var result = collection.FindOneAndUpdateAsync(filter, update).Result;

または、ラムダを使用して、もう少し簡潔に:

var update = Builders<Person>.Update.PullFilter(p => p.followerList,
                                                f => f.follower == "fethiye");
var result = collection
    .FindOneAndUpdateAsync(p => p.username == "bodrum", update).Result;
46
JohnnyHK

コレクション名がPersonであるとすると、PullFilterを使用して配列からレコードを削除できます。

var filterBuilder = Builders<Person>.Filter.Eq(person => person.username, "bodrum");

var updateBuilder = Builders<Person>.Update.PullFilter(p => p.followerList,
                       Builders<Person>.Filter.Eq(per => per.follower, "fethiye"));

var updateResult = collection.UpdateOne(filterBuilder, updateBuilder);

Console.WriteLine(
            $"MatchedCount: {updateResult.MatchedCount}, ModifiedCount: {updateResult.ModifiedCount}");

フィルターされたドキュメント内の値の配列も削除する必要がある場合は、更新ビルダーをこの行に置き換えることができます

var updateBuilder = Builders<Person>.Update.PullFilter(p => p.followerList,
                   Builders<Person>.Filter.In(per => per.follower, new List<string> {"fethiye", "izmir"}));

また、多くのドキュメントを保存するには、updateOneをupdateManyに置き換えることができます

var updateResult = collection.UpdateMany(filterBuilder, updateBuilder);
2
deeps

これは、ネストされた配列オブジェクトを削除するために使用するものです

-parentpath:followerList
-プロパティ:follower
-値:fethiye.png

var filter = new BsonDocument("_id", ObjectId.Parse(id));

    var updateValues = Builders<object>.Update.PullFilter(parentPath,
        Builders<object>.Filter.Eq(propertie, value));
        DatabaseCollection.FindOneAndUpdate(filter, updateValues);

より深くネストされた配列オブジェクトを削除する例:
名前Doeのオブジェクトを削除しましょう

-parentPath:followerList.0.testArray
-propertie:name
-value:Doe

    {
  "_id": ObjectId("554e05dfc90d3d4dfcaa2aea"),
  "username": "bodrum",
  "followerList": [
    {
      "_id": ObjectId("554e0625a51586362c33c6df"),
      "follower": "fethiye",
      "testArray": [
{
"name":"John"
},
{
"name":"Doe"
},
{
"name":"Jason"
}
]
    },
    {
      "_id": ObjectId("554e0625a51586362c33c6df"),
      "follower": "izmir",
      "avatar": "izmir.png"
    }
  ]
} 
1
windrider63

MongoDB.Entities を使用して、はるかに簡単なソリューションを提供できます。 personおよびfollowersは独自のコレクションに格納され、1対多の関係を表します。

using System.Linq;
using MongoDB.Entities;

namespace StackOverflow
{
    public class Person : Entity
    {
        public string Username { get; set; }
        public Many<Follower> FollowerList { get; set; }

        public Person() => this.InitOneToMany(() => FollowerList);
    }

    public class Follower : Entity
    {
        public string Name { get; set; }
        public string Avatar { get; set; }
    }

    class Program
    {
        static void Main(string[] args)
        {
            new DB("followers");

            var person1 = new Person { Username = "bodrum"};
            person1.Save();

            var follower1 = new Follower { Name = "fethiye", Avatar= "fethiye.png" };
            follower1.Save();

            var follower2 = new Follower { Name = "izmir", Avatar = "izmir.png" };
            follower2.Save();

            person1.FollowerList.Add(follower1);
            person1.FollowerList.Add(follower2);

            var fathiye = person1.FollowerList.Collection()
                                              .Where(p => p.Name == "fethiye")
                                              .FirstOrDefault();

            person1.FollowerList.Remove(fathiye);
        }
    }
}