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

MongoDB/PHP:hapus elemen dari array

Selamat,

Operator $pull tidak akan bekerja pada dokumen yang Anda gunakan, karena kunci "notifikasi" sebenarnya bukan array. Ini lebih merupakan dokumen yang disematkan, dengan kunci bernomor, membuatnya menyerupai sebuah array. Tidak ada cara (yang saya tahu) untuk mempertahankan struktur dokumen ini dan tombol bernomor diganti namanya secara otomatis.

Jika Anda sedikit memfaktorkan ulang dokumen Anda, agar terlihat seperti ini:

{
   "notifications": [
    {
       "type": "privateMessage",
       "fromUname": "Eamorr2",
       "time": 1292773522,
       "id": "1lfw70h789u13a1e67pv"
    },
    {
       "type": "privateMessage",
       "fromUname": "Eamorr2",
       "time": 1292773522,
       "id": "iwoidjsoskqp23nlwof"
    }
  ],
   "toUname": "Eamorr"
}

Unsur-unsur masih akan diberi nomor, secara implisit. Sekarang menjadi array, jadi Anda mendapatkannya secara gratis. Anda dapat menggunakan operator $pull seperti ini (saya tidak terbiasa dengan driver PHP, jadi saya memberi Anda shell yang setara):

db.messages.update({ "toUname" : "Eamorr" }, { $pull : { "notifications" : { "id" : "1lfw70h789u13a1e67pv" }}});

Saya secara sewenang-wenang menggunakan kunci "toUname" untuk mengidentifikasi dokumen, tetapi saya kira Anda ingin menggunakan bidang _id. Juga, saya menggunakan kunci "id" dari pesan untuk mengidentifikasi pesan yang akan ditarik dari array, karena jauh lebih aman dan memastikan Anda tidak secara tidak sengaja menghapus pesan yang salah jika array telah berubah sejak Anda mengidentifikasi ordinal larik yang akan dihapus.

Semoga membantu.




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Membuat tampilan mongo yang bergantung pada waktu saat ini

  2. Mongodb membuat alias dalam kueri

  3. Spring Boot menghubungkan Mysql dan MongoDb

  4. bagaimana cara menambahkan --auth untuk gambar mongodb saat menggunakan docker-compose?

  5. MongoDB $count Operator Agregasi