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

Cara membuat kueri bersarang di MongoDb yang berfungsi seperti kueri pemilihan Sql bersarang

Jawaban atas pertanyaan seperti itu di MongoDB sering kali membuat data Anda tidak normal. Jika Anda hanya membutuhkan daftar pengguna dalam grup, Anda dapat menyimpan ID pengguna dan nama pengguna dalam dokumen grup. Dalam beberapa hal, Anda menyusun database sesuai dengan hasil yang ingin Anda lihat di layar daripada mencoba memasukkannya ke dalam format yang dinormalisasi.

Jelas itu hanya akan berfungsi jika daftar grup pengguna Anda (dengan nama) dapat ditampung dalam satu dokumen, tetapi pendekatan Anda saat ini juga memiliki beberapa batasan mengenai ukuran maksimum grup.

Pendekatan lain adalah dengan menyimpan grup tempat pengguna berada dalam larik pada setiap dokumen 'Pengguna'. Tambahkan indeks pada bidang array itu dan sekarang Anda dapat menemukan pengguna berdasarkan grup. Mengingat bahwa pengguna cenderung menjadi anggota grup yang lebih sedikit daripada jumlah anggota dalam grup, ini mungkin merupakan pendekatan terbaik di sini.

db.user.save({_id:"u1", name:"u1 name", groups:[{_id:"g1", name:"Group One"}, ...]});

Sekali lagi Anda dapat menyimpan nama grup dengan _id-nya sehingga Anda dapat segera menampilkan daftar grup milik pengguna dengan satu perjalanan pulang pergi. Tentu saja, jika Anda mengizinkan nama grup berubah, Anda harus memulai tugas latar belakang untuk memperbaiki semua salinan nama ini.

Saya juga akan menggunakan generator id MongoDB bawaan daripada milik Anda sendiri, ia memiliki banyak properti yang diinginkan.



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Bagaimana mengatasi MongoError:pool hancur saat terhubung ke CosmosDB

  2. Tidak dapat memulai ulang mongodb di Ubuntu 11.04

  3. Di Mongo, adakah cara untuk melakukan pemeriksaan dan pengaturan seperti operasi atom?

  4. MongoDB.Driver.Builders cara mengelompokkan dan mendapatkan rata-rata

  5. Temukan luwak dengan beberapa kondisi