MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

C# Mongodb. Намерете елемент в масива и изберете само този елемент

Опитайте това

        var mongoClient = new MongoClient();
        var collection = mongoClient.GetDatabase("test").GetCollection<Rootobject>("test");

        ObjectId someId = new ObjectId("599e670f2720317af451db9e");
        string someName = "Car 1";

        var item = await collection.AsQueryable()
            .Where(x => x.Id == someId)
            .SelectMany(x => x.Cars)
            .Where(x => x.Name == someName)
            .FirstOrDefaultAsync();

Това генерира следната заявка за агрегиране:

{aggregate([{ "$match" : { "_id" : ObjectId("599e670f2720317af451db9e") } }, { "$unwind" : "$Cars" }, { "$project" : { "Cars" : "$Cars", "_id" : 0 } }, { "$match" : { "Cars.Name" : "Car 1" } }])}

което извежда следните резултати:

{ "Cars" : { "Name" : "Car 1", "Labels" : [ { "Label" : "Main", "Color" : "#F49973" } ] } }



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. BASH BSON анализатор

  2. Има ли компонент Polymer, който опростява комуникацията с MongoDB?

  3. Монгоидни агрегатни методи на вградени документи?

  4. Mongoose агрегат, не може динамично да добави someField:{ $not; нула }

  5. Получаване на най-високата стойност на колона в MongoDB