MongoDB
 sql >> Teknologi Basis Data >  >> NoSQL >> MongoDB

C# Mongodb. Temukan item dalam array dan pilih hanya item ini

Coba ini

        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();

Ini menghasilkan kueri agregasi di bawah ini:

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

yang mengeluarkan hasil sebagai berikut:

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



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB dapatkan semua bidang + urutkan berdasarkan nilai yang dihitung dari beberapa bidang

  2. mpromise (perpustakaan janji default luwak) adalah kesalahan yang tidak digunakan lagi saat pengujian

  3. NodeJS, Mongoose:Cara mendapatkan data terkait menggunakan luwak

  4. MongoCursorException - Kursor tidak ditemukan (Pengandar PHP MongoDB)

  5. Bagaimana saya bisa menulis agregasi tanpa melebihi ukuran dokumen maksimum?