Python MongoDB Belge Ekleme

MongoDB'deki belgeler, SQL veritabanlarındaki kayıtlarla aynıdır.

Koleksiyona ekleme

Kayıtları veya belgeleri, yani bizim adlandırdığımız belgeleri MongoDB koleksiyonuna eklemek için kullanırız: insert_one() Metod.

insert_one() Metodun ilk parametresi, belgeye eklemek istediğiniz her alanın adı ve değeri içeren bir sözlüktür.

Örnek

"customers" koleksiyonuna kayıt ekleyin:

import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
mydict = { "name": "Bill", "address": "Highway 37" }
x = mycol.insert_one(mydict)

Örnek Çalıştır

_id alanını döndürür

insert_one() Metot, InsertOneResult nesnesi döndürür, bu nesne özelliklere sahiptir inserted_ideklenen belgelerin id'lerini kaydetmek için kullanılır.

Örnek

"customers" koleksiyonuna bir diğer kayıt ekleyin ve _id alanının değerini döndürün:

mydict = { "name": "Peter", "address": "Lowstreet 27" }
x = mycol.insert_one(mydict)
print(x.inserted_id)

Örnek Çalıştır

Belirtmemişseniz _id Alanı belirtilmemişse, MongoDB sizi için bir tane ekler ve her belgeye benzersiz bir ID atar.

Örnekte belirtilmemiş _id Alanı, bu yüzden MongoDB, kayıtlar (belgeler) için benzersiz bir _id atar.

Çok sayıda belge ekleme

Çok sayıda belgeyi MongoDB koleksiyonuna eklemek için kullanırız: insert_many() Metod.

insert_many() Methodun ilk parametresi, eklemek istediğiniz verileri içeren bir sözlük listesidir:

Örnek

import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
mylist = [
  {"name": "Amy", "address": "Apple st 652"},
  {"name": "Hannah", "address": "Mountain 21"},
  {"name": "Michael", "address": "Valley 345"},
  {"name": "Sandy", "address": "Ocean blvd 2"},
  {"name": "Betty", "address": "Green Grass 1"},
  {"name": "Richard", "address": "Sky st 331"},
  {"name": "Susan", "address": "One way 98"},
  { "name": "Vicky", "address": "Yellow Garden 2"},
  { "name": "Ben", "address": "Park Lane 38"},
  { "name": "William", "address": "Central st 954"},
  { "name": "Chuck", "address": "Main Road 989"},
  { "name": "Viola", "address": "Sideway 1633"}
]
x = mycol.insert_many(mylist)
# Eklendiği belgelerin _id değerlerini listeleyen yazdırma:
print(x.inserted_ids)

Örnek Çalıştır

insert_many() metodu InsertManyResult nesnesi döndürür, bu nesne özelliklere sahiptir inserted_idseklenen belgelerin id'lerini kaydetmek için kullanılır.

Belirtilmiş ID ile birden fazla belge ekleme

MongoDB'nin belgelerinize benzersiz bir id atamasını istemiyorsanız, belge eklerken _id alanını belirtebilirsiniz.

Değerlerin benzersiz olması gerekmektedir. İki dosya aynı _id değeri taşıyamaz.

Örnek

import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
mylist = [
  { "_id": 1, "name": "John", "address": "Highway 37"},
  { "_id": 2, "name": "Peter", "address": "Lowstreet 27"},
  { "_id": 3, "name": "Amy", "address": "Apple st 652"},
  { "_id": 4, "name": "Hannah", "address": "Mountain 21"},
  { "_id": 5, "name": "Michael", "address": "Valley 345"},
  { "_id": 6, "name": "Sandy", "address": "Ocean blvd 2"},
  { "_id": 7, "name": "Betty", "address": "Green Grass 1"},
  {"_id": 8, "name": "Richard", "address": "Sky st 331"}
  {"_id": 9, "name": "Susan", "address": "One way 98"},
  {"_id": 10, "name": "Vicky", "address": "Yellow Garden 2"},
  {"_id": 11, "name": "Ben", "address": "Park Lane 38"},
  {"_id": 12, "name": "William", "address": "Central st 954"},
  {"_id": 13, "name": "Chuck", "address": "Main Road 989"},
  {"_id": 14, "name": "Viola", "address": "Sideway 1633"}
]
x = mycol.insert_many(mylist)
# Eklendiği belgelerin _id değerlerini listeleyen yazdırma:
print(x.inserted_ids)

Örnek Çalıştır