Mulai mongoimport
versi 100.0.0, Anda dapat menghapus dokumen di MongoDB berdasarkan file yang diimpor. Untuk melakukannya, gunakan delete
modus.
Saat Anda menggunakan delete
mode, jika dokumen yang diimpor memiliki _id
yang sama nilai sebagai yang sudah ada dalam koleksi yang Anda impor, dokumen yang ada akan dihapus.
Anda juga dapat menentukan bidang atau bidang lain (selain _id
bidang) menjadi bidang yang cocok jika diperlukan.
Contoh
Misalkan kita memiliki koleksi yang disebut pets
yang berisi dokumen-dokumen berikut:
db.pets.find()
Hasil:
{ "_id" :1, "name" :"Wag", "type" :"Dog", "weight" :20 }{ "_id" :2, "name" :"Bark", "type" :"Anjing", "berat" :10 }{ "_id" :3, "name" :"Meow", "type" :"Cat", "weight" :7 }{ "_id" :4, "name" :"Scratch", "type" :"Cat", "weight" :8 }{ "_id" :5, "name" :"Bruce", "type" :"Bat", "weight" :3 }Dan kami memiliki file JSON berikut bernama
pets.json
:{"_id":1,"name":"Wag","type":"Anjing"}{"_id":2,"name":"Fluffy","type":"Cat"," weight":10}{"_id":9,"name":"Hop","type":"Kangaroo","weight":60}Perintah berikut mengimpor file JSON menggunakan
delete
modus:mongoimport --db=PetHotel --collection=pets --mode=delete --file=data/pets.json
Menjalankan perintah ini akan menghapus semua dokumen yang cocok dalam koleksi.
Periksa Hasil
Yuk intip koleksinya sekarang.
db.pets.find()
Hasil:
{ "_id" :3, "name" :"Meow", "type" :"Cat", "weight" :7 }{ "_id" :4, "name" :"Scratch", "type" :"Cat", "weight" :8 }{ "_id" :5, "name" :"Bruce", "type" :"Bat", "weight" :3 }Kita dapat melihat bahwa 2 dokumen pertama telah dihapus. Mereka dihapus karena
_id
their mereka nilai cocok dengan_id
nilai dalam dokumen yang ada. Ini terlepas dari detail lain yang belum tentu cocok (seperti dengan dokumen 2).Juga, file yang kami impor memiliki dokumen dengan
_id
dari 9 tetapi tidak ada dokumen yang cocok, jadi tidak ada yang dihapus untuk dokumen itu.Ubah Bidang Bagian Atas
Anda dapat menggunakan
--upsertFields
parameter untuk menentukan bidang selain_id
yang harus dicocokkan. Saat menggunakan beberapa bidang dengan parameter ini, berikan sebagai daftar yang dipisahkan koma.Misalkan kita memiliki file JSON lain bernama
pets2.json
dan tampilannya seperti ini:{ "name" :"Meow", "type" :"Cat", "weight" :7 }{ "name" :"Bubbles", "type" :"Fish", "weight" :3 }Dokumen ini tidak menyertakan
_id
bidang, jadi kami harus mencocokkan bidang lain yang secara unik mengidentifikasi setiap dokumen. Dalam hal ini kita bisa menggunakanname
dantype
bidang.Oleh karena itu, kita dapat menggunakan
mongoimport
berikut ini:perintah:mongoimport --db=PetHotel --collection=pets --mode=delete --upsertFields=name,type --file=data/pets2.json
Sekarang mari kita periksa kembali koleksinya:
db.pets.find()
Hasil:
{ "_id" :4, "name" :"Scratch", "type" :"Cat", "weight" :8 }{ "_id" :5, "name" :"Bruce", "type" :"Kelelawar", "berat" :3 }Meow si kucing dihapus karena hewan peliharaan itu ada di koleksi MongoDB dan dokumen yang diimpor.
Gelembung ikan tidak memiliki dokumen yang cocok sehingga tidak ada yang dihapus untuk dokumen itu.
Periksa
mongoimport
mongoimport
adalah bagian dari paket Alat Database MongoDB. Alat Database MongoDB adalah rangkaian utilitas baris perintah untuk bekerja dengan MongoDB.Jika Anda tidak yakin apakah Anda memiliki MongoDB Database Tools/
mongoimport
terinstal, coba jalankan perintah berikut di Terminal atau Command Prompt Anda untuk memeriksa:mongoimport --version
Jika Anda memilikinya, Anda akan melihat informasi versi, dll. Jika Anda tidak memilikinya, Anda dapat menggunakan petunjuk penginstalan di situs web MongoDB untuk menginstalnya ke sistem Anda.
Di mana Menjalankan Perintah?
Jangan lupa, Anda harus menjalankan
mongoimport
perintah dari baris perintah sistem Anda (mis. Terminal baru atau jendela Prompt Perintah).Jangan jalankan dari
mongo
kerang.