अजगर MongoDB - त्वरित गाइड

पाइमोन्गो एक अजगर वितरण है जो MongoDB के साथ काम करने के लिए उपकरण प्रदान करता है, यह अजगर से MongoDB डेटाबेस के साथ संवाद करने का सबसे पसंदीदा तरीका है।

इंस्टालेशन

सब से पहले pymongo स्थापित करने के लिए सुनिश्चित करें कि आपने python3 (PIP के साथ) और MongoDB को ठीक से स्थापित किया है। फिर निम्नलिखित कमांड निष्पादित करें।

C:\WINDOWS\system32>pip install pymongo
Collecting pymongo
Using cached https://files.pythonhosted.org/packages/cb/a6/b0ae3781b0ad75825e00e29dc5489b53512625e02328d73556e1ecdf12f8/pymongo-3.9.0-cp37-cp37m-win32.whl
Installing collected packages: pymongo
Successfully installed pymongo-3.9.0

सत्यापन

एक बार जब आपने pymongo इंस्टॉल कर लिया है, तो एक नया टेक्स्ट डॉक्यूमेंट खोलें, इसमें निम्न लाइन पेस्ट करें और, इसे test.py के रूप में सहेजें।

import pymongo

यदि आपने pymongo को ठीक से स्थापित किया है, यदि आप नीचे दिखाए गए अनुसार test.py निष्पादित करते हैं, तो आपको कोई समस्या नहीं होनी चाहिए।

D:\Python_MongoDB>test.py
D:\Python_MongoDB>

अन्य डेटाबेस के विपरीत, MongoDB डेटाबेस बनाने के लिए अलग कमांड प्रदान नहीं करता है।

सामान्य तौर पर, विशिष्ट डेटाबेस का चयन / स्विच करने के लिए उपयोग कमांड का उपयोग किया जाता है। यह कमांड शुरू में सत्यापित करता है कि क्या हमारे द्वारा निर्दिष्ट डेटाबेस मौजूद है, यदि हां, तो यह इससे जुड़ता है। यदि डेटाबेस, हम उपयोग कमांड के साथ निर्दिष्ट करते हैं, तो नया डेटाबेस नहीं बनाया जाएगा।

इसलिए, आप का उपयोग करके MongoDB में एक डेटाबेस बना सकते हैं Use आदेश।

वाक्य - विन्यास

का मूल सिंटैक्स use DATABASE कथन इस प्रकार है -

use DATABASE_NAME

उदाहरण

निम्न कमांड mydb में एक डेटाबेस बनाता है।

>use mydb
switched to db mydb

आप db कमांड का उपयोग करके अपनी रचना को सत्यापित कर सकते हैं , यह वर्तमान डेटाबेस को प्रदर्शित करता है।

>db
mydb

पायथन का उपयोग करके डेटाबेस बनाना

Pymongo का उपयोग करके MongoDB से कनेक्ट करने के लिए, आपको MongoClient को आयात और बनाने की आवश्यकता है, फिर आप उस डेटाबेस तक सीधे पहुंच सकते हैं जिसे आपको विशेषता जुनून में बनाने की आवश्यकता है।

उदाहरण

निम्न उदाहरण MangoDB में एक डेटाबेस बनाता है।

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['mydb']
print("Database created........")

#Verification
print("List of databases after creating new one")
print(client.list_database_names())

उत्पादन

Database created........
List of databases after creating new one:
['admin', 'config', 'local', 'mydb']

आप MongoClient बनाते समय पोर्ट और होस्ट नामों को भी निर्दिष्ट कर सकते हैं और शब्दकोश शैली में डेटाबेस तक पहुंच सकते हैं।

उदाहरण

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['mydb']
print("Database created........")

उत्पादन

Database created........

MongoDB में एक संग्रह दस्तावेजों का एक समूह रखता है, यह संबंधपरक डेटाबेस में एक तालिका के अनुरूप है।

आप का उपयोग कर एक संग्रह बना सकते हैं createCollection()तरीका। यह विधि बनाए जाने वाले संग्रह के नाम और एक विकल्प (वैकल्पिक) पैरामीटर का प्रतिनिधित्व करने वाले स्ट्रिंग मान को स्वीकार करता है।

इसके प्रयोग से आप निम्नलिखित निर्दिष्ट कर सकते हैं -

  • संग्रह का आकार

  • अधिकतम छाया हुआ संग्रह में अनुमति दस्तावेजों की संख्या।

  • क्या हमारे द्वारा बनाया गया संग्रह छायांकित संग्रह (निश्चित आकार संग्रह) होना चाहिए।

  • क्या हमारे द्वारा बनाया गया संग्रह ऑटो-इंडेक्स होना चाहिए।

वाक्य - विन्यास

MongoDB में एक संग्रह बनाने के लिए निम्नलिखित सिंटैक्स है।

db.createCollection("CollectionName")

उदाहरण

निम्नलिखित विधि एक संग्रह बनाती है जिसका नाम ExampleCollection है।

> use mydb
switched to db mydb
> db.createCollection("ExampleCollection")
{ "ok" : 1 }
>

इसी तरह, निम्नलिखित एक क्वेरी है जो createCollection () विधि के विकल्पों का उपयोग करके एक संग्रह बनाता है।

>db.createCollection("mycol", { capped : true, autoIndexId : true, size :
6142800, max : 10000 } )
{ "ok" : 1 }
>

पायथन का उपयोग करके एक संग्रह बनाना

अजगर उदाहरण के बाद MongoDB (mydb) में एक डेटाबेस से जुड़ता है और, इसमें एक संग्रह बनाता है।

उदाहरण

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['mydb']

#Creating a collection
collection = db['example']
print("Collection created........")

उत्पादन

Collection created........

आप सम्मिलित करें () विधि का उपयोग करके दस्तावेजों को MongoDB में संग्रहीत कर सकते हैं । यह विधि एक JSON दस्तावेज़ को एक पैरामीटर के रूप में स्वीकार करती है।

वाक्य - विन्यास

निम्नलिखित सम्मिलित विधि का वाक्यविन्यास है।

>db.COLLECTION_NAME.insert(DOCUMENT_NAME)

उदाहरण

> use mydb
switched to db mydb
> db.createCollection("sample")
{ "ok" : 1 }
> doc1 = {"name": "Ram", "age": "26", "city": "Hyderabad"}
{ "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
> db.sample.insert(doc1)
WriteResult({ "nInserted" : 1 })
>

इसी तरह, आप भी कई दस्तावेजों का उपयोग कर सम्मिलित कर सकते हैं insert() तरीका।

> use testDB
switched to db testDB
> db.createCollection("sample")
{ "ok" : 1 }
> data = [
   {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"}, 
   {"_id": "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }, 
   {"_id": "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
]
[
   {"_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad"},
   {"_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore"},
   {"_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai"}
]
> db.sample.insert(data)
BulkWriteResult({
   "writeErrors" : [ ],
   "writeConcernErrors" : [ ],
   "nInserted" : 3,
   "nUpserted" : 0,
   "nMatched" : 0,
   "nModified" : 0,
   "nRemoved" : 0,
   "upserted" : [ ]
})
>

पायथन का उपयोग करके एक संग्रह बनाना

मैंगोबीड में एक दस्तावेज़ सम्मिलित करने के लिए Pymongo Insert_one () नामक एक विधि प्रदान करता है। इस पद्धति के लिए, हमें दस्तावेज़ को शब्दकोश प्रारूप में पास करना होगा।

उदाहरण

निम्नलिखित उदाहरण संग्रह नाम के उदाहरण में एक दस्तावेज़ सम्मिलित करता है।

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['mydb']

#Creating a collection
coll = db['example']

#Inserting document into a collection
doc1 = {"name": "Ram", "age": "26", "city": "Hyderabad"}
coll.insert_one(doc1)
print(coll.find_one())

उत्पादन

{'_id': ObjectId('5d63ad6ce043e2a93885858b'), 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}

Pymongo का उपयोग करते हुए MongoDB में कई दस्तावेज़ सम्मिलित करने के लिए, आपको insert_many () विधि को लागू करना होगा।

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['mydb']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
print(res.inserted_ids)

उत्पादन

Data inserted ......
['101', '102', '103']

आप MongoDB से संग्रहीत दस्तावेजों को पढ़ / प्राप्त कर सकते हैं find()तरीका। यह विधि गैर-संरचित तरीके से MongoDB में सभी दस्तावेजों को पुनर्प्राप्त और प्रदर्शित करती है।

वाक्य - विन्यास

निम्नलिखित का सिंटैक्स है find() तरीका।

>db.COLLECTION_NAME.find()

उदाहरण

मान लें कि हमने निम्नलिखित प्रश्नों का उपयोग करते हुए नमूने नाम के एक संग्रह में testDB नामक डेटाबेस में 3 दस्तावेज़ सम्मिलित किए हैं -

> use testDB
> db.createCollection("sample")
> data = [
   {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" },
   {"_id": "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
]
> db.sample.insert(data)

आप खोजे गए () विधि का उपयोग करके सम्मिलित किए गए दस्तावेजों को पुनः प्राप्त कर सकते हैं -

> use testDB
switched to db testDB
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
>

आप संग्रह में पहला दस्तावेज़ पुनः प्राप्त कर सकते हैं जैसे कि खोज () विधि का उपयोग करके -

> db.sample.findOne()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }

डेटा पुनर्प्राप्त करना (ढूंढें) पायथन का उपयोग करना

find_One() pymongo की विधि का उपयोग आपकी क्वेरी के आधार पर एक एकल दस्तावेज़ को पुनः प्राप्त करने के लिए किया जाता है, कोई भी मैच के मामले में यह विधि कुछ भी नहीं लौटाती है और यदि आप किसी भी क्वेरी का उपयोग नहीं करते हैं तो यह संग्रह का पहला दस्तावेज़ लौटाता है।

जब भी आपको किसी परिणाम के केवल एक दस्तावेज़ को प्राप्त करने की आवश्यकता होती है, तो यह विधि काम आती है, या यदि आप सुनिश्चित हैं कि आपकी क्वेरी केवल एक दस्तावेज़ लौटाती है।

उदाहरण

अजगर उदाहरण के बाद एक संग्रह का पहला दस्तावेज प्राप्त होता है -

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['mydatabase']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
print(res.inserted_ids)

#Retrieving the first record using the find_one() method
print("First record of the collection: ")
print(coll.find_one())

#Retrieving a record with is 103 using the find_one() method
print("Record whose id is 103: ")
print(coll.find_one({"_id": "103"}))

उत्पादन

Data inserted ......
['101', '102', '103']
First record of the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
Record whose id is 103:
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}

एक ही क्वेरी में कई दस्तावेज़ प्राप्त करने के लिए (एकल कॉल ऑड फ़ाइंड विधि), आप इसका उपयोग कर सकते हैं find()पाइमोन्गो की विधि। यदि आपने कोई क्वेरी पारित नहीं की है, तो यह एक संग्रह के सभी दस्तावेजों को लौटाता है और, यदि आपने इस पद्धति से कोई क्वेरी पारित की है, तो यह सभी मिलान दस्तावेजों को लौटाता है।

उदाहरण

#Getting the database instance
db = client['myDB']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Retrieving all the records using the find() method
print("Records of the collection: ")
for doc1 in coll.find():
   print(doc1)

#Retrieving records with age greater than 26 using the find() method
print("Record whose age is more than 26: ")
for doc2 in coll.find({"age":{"$gt":"26"}}):
   print(doc2)

उत्पादन

Data inserted ......
Records of the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Record whose age is more than 26:
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}

का उपयोग करते हुए पुनः प्राप्त find()विधि, आप क्वेरी ऑब्जेक्ट का उपयोग करके दस्तावेज़ों को फ़िल्टर कर सकते हैं। आप इस विधि के लिए एक पैरामीटर के रूप में आवश्यक दस्तावेजों के लिए शर्त निर्दिष्ट करने वाली क्वेरी को पास कर सकते हैं।

ऑपरेटर्स

निम्नलिखित MongoDB में प्रश्नों में प्रयुक्त ऑपरेटरों की सूची है।

ऑपरेशन वाक्य - विन्यास उदाहरण
समानता {"मौलिक मूल्य"} db.mycol.find ({"by": "ट्यूटोरियल्स पॉइंट"})
से कम {"कुंजी": {$ lt: "value"}} db.mycol.find ({ "पसंद": {$ lt: 50}})
बराबरी से कम {"कुंजी": {$ lte: "मूल्य"}} db.mycol.find ({ "पसंद": {$ एलटीई: 50}})
से अधिक {"कुंजी": {$ gt: "मान"}} db.mycol.find ({ "पसंद": {$ जीटी: 50}})
ग्रेटर थान बराबर {"कुंजी" {$ gte: "मूल्य"}} db.mycol.find ({ "पसंद": {$ gte: 50}})
न के बराबर {"कुंजी": {$ ne: "मान"}} db.mycol.find ({ "पसंद": {$ ne: 50}})

उदाहरण 1

निम्नलिखित उदाहरण एक संग्रह में दस्तावेज़ को पुनः प्राप्त करता है जिसका नाम सरिस्ता है।

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['sdsegf']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
   {"_id": "1004", "name": "Romeo", "age": "25", "city": "Pune"},
   {"_id": "1005", "name": "Sarmista", "age": "23", "city": "Delhi"},
   {"_id": "1006", "name": "Rasajna", "age": "26", "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Retrieving data
print("Documents in the collection: ")
for doc1 in coll.find({"name":"Sarmista"}):
   print(doc1)

उत्पादन

Data inserted ......
Documents in the collection:
{'_id': '1005', 'name': 'Sarmista', 'age': '23', 'city': 'Delhi'}

example2

निम्नलिखित उदाहरण एक संग्रह में दस्तावेज़ को पुनः प्राप्त करता है, जिसकी आयु मूल्य 26 से अधिक है।

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['ghhj']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
   {"_id": "1004", "name": "Romeo", "age": "25", "city": "Pune"},
   {"_id": "1005", "name": "Sarmista", "age": "23", "city": "Delhi"},
   {"_id": "1006", "name": "Rasajna", "age": "26", "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Retrieving data
print("Documents in the collection: ")
for doc in coll.find({"age":{"$gt":"26"}}):
   print(doc)

उत्पादन

Data inserted ......
Documents in the collection:
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}

किसी संग्रह की सामग्री को पुनर्प्राप्त करते समय, आप उन्हें उपयोग करके आरोही या अवरोही क्रमों में क्रमबद्ध और व्यवस्थित कर सकते हैं sort() तरीका।

इस पद्धति के लिए, आप फ़ील्ड (एस) और सॉर्टिंग क्रम जो 1 या -1 पास कर सकते हैं। जहां, 1 आरोही क्रम के लिए है और -1 अवरोही क्रम है।

वाक्य - विन्यास

निम्नलिखित प्रकार () विधि का वाक्यविन्यास है ।

>db.COLLECTION_NAME.find().sort({KEY:1})

उदाहरण

मान लें कि हमने एक संग्रह बनाया है और उसमें 5 दस्तावेज़ डाले हैं जैसा कि नीचे दिखाया गया है -

> use testDB
switched to db testDB
> db.createCollection("myColl")
{ "ok" : 1 }
> data = [
   ... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   ... {"_id": "1002", "name": "Rahim", "age": 27, "city": "Bangalore"},
   ... {"_id": "1003", "name": "Robert", "age": 28, "city": "Mumbai"},
   ... {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
   ... {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
   ... {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
> db.sample.insert(data)
BulkWriteResult({
   "writeErrors" : [ ],
   "writeConcernErrors" : [ ],
   "nInserted" : 6,
   "nUpserted" : 0,
   "nMatched" : 0,
   "nModified" : 0,
   "nRemoved" : 0,
   "upserted" : [ ]
})

निम्नलिखित पंक्ति संग्रह के सभी दस्तावेजों को पुनः प्राप्त करती है जो आयु के आधार पर आरोही क्रम में क्रमबद्ध होते हैं।

> db.sample.find().sort({age:1})
{ "_id" : "1005", "name" : "Sarmista", "age" : 23, "city" : "Delhi" }
{ "_id" : "1004", "name" : "Romeo", "age" : 25, "city" : "Pune" }
{ "_id" : "1006", "name" : "Rasajna", "age" : 26, "city" : "Chennai" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }

पायथन का उपयोग करके दस्तावेज़ों को क्रमबद्ध करना

आरोही में किसी क्वेरी के परिणामों को क्रमबद्ध करने के लिए, अवरोही क्रम pymongo प्रदान करता है sort()तरीका। इस पद्धति के लिए, परिणाम में आपके द्वारा आवश्यक दस्तावेजों की संख्या का प्रतिनिधित्व करने वाला एक संख्या मान पास करें।

डिफ़ॉल्ट रूप से, यह विधि निर्दिष्ट क्षेत्र के आधार पर दस्तावेजों को आरोही क्रम में क्रमबद्ध करती है। यदि आपको फ़ील्ड नाम के साथ अवरोही क्रम पास -1 क्रमबद्ध करना होगा -

coll.find().sort("age",-1)

उदाहरण

निम्नलिखित उदाहरण संग्रह के सभी दस्तावेजों को आरोही क्रम में आयु मानों के अनुसार व्यवस्थित करते हैं -

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['b_mydb']

#Creating a collection
coll = db['myColl']

#Inserting document into a collection
data = [
   {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
   {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
   {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
   {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Retrieving first 3 documents using the find() and limit() methods
print("List of documents (sorted in ascending order based on age): ")
for doc1 in coll.find().sort("age"):
   print(doc1)

उत्पादन

Data inserted ......
List of documents (sorted in ascending order based on age):
{'_id': '1005', 'name': 'Sarmista', 'age': 23, 'city': 'Delhi'}
{'_id': '1004', 'name': 'Romeo', 'age': 25, 'city': 'Pune'}
{'_id': '1006', 'name': 'Rasajna', 'age': 26, 'city': 'Chennai'}
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}

आप किसी संग्रह में दस्तावेज़ों का उपयोग करके हटा सकते हैं remove()MongoDB की विधि। यह विधि दो वैकल्पिक मापदंडों को स्वीकार करती है -

  • दस्तावेज़ हटाने के लिए स्थिति निर्दिष्ट करने वाले हटाए गए मानदंड।

  • केवल एक, यदि आप दूसरे पैरामीटर के रूप में सही या 1 पास करते हैं, तो केवल एक ही दस्तावेज़ हटा दिया जाएगा।

वाक्य - विन्यास

निम्नलिखित निकालें () विधि का वाक्य विन्यास है -

>db.COLLECTION_NAME.remove(DELLETION_CRITTERIA)

उदाहरण

मान लें कि हमने एक संग्रह बनाया है और उसमें 5 दस्तावेज़ डाले हैं जैसा कि नीचे दिखाया गया है -

> use testDB
switched to db testDB
> db.createCollection("myColl")
{ "ok" : 1 }
> data = [
   ... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   ... {"_id": "1002", "name": "Rahim", "age": 27, "city": "Bangalore"},
   ... {"_id": "1003", "name": "Robert", "age": 28, "city": "Mumbai"},
   ... {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
   ... {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
   ... {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
> db.sample.insert(data)
BulkWriteResult({
   "writeErrors" : [ ],
   "writeConcernErrors" : [ ],
   "nInserted" : 6,
   "nUpserted" : 0,
   "nMatched" : 0,
   "nModified" : 0,
   "nRemoved" : 0,
   "upserted" : [ ]
})

निम्नलिखित क्वेरी उस संग्रह के दस्तावेज़ (ओं) को हटा देती है जिनका नाम मूल्य Sarmista है।

> db.sample.remove({"name": "Sarmista"})
WriteResult({ "nRemoved" : 1 })
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
{ "_id" : "1004", "name" : "Romeo", "age" : 25, "city" : "Pune" }
{ "_id" : "1006", "name" : "Rasajna", "age" : 26, "city" : "Chennai" }

अगर तुम आह्वान करते हो remove() विलोपन मानदंड को पारित किए बिना विधि, संग्रह में सभी दस्तावेजों को हटा दिया जाएगा।

> db.sample.remove({})
WriteResult({ "nRemoved" : 5 })
> db.sample.find()

पायथन का उपयोग करके दस्तावेज़ हटाना

MangoDB के संग्रह से दस्तावेज़ों को हटाने के लिए, आप विधियों का उपयोग करके संग्रह से दस्तावेज़ों को हटा सकते हैं delete_one() तथा delete_many() तरीकों।

ये विधियाँ दस्तावेजों को हटाने के लिए शर्त निर्दिष्ट करने वाली एक क्वेरी ऑब्जेक्ट को स्वीकार करती हैं।

एक मेल के मामले में, detele_one () विधि एकल दस्तावेज़ को हटा देती है। यदि कोई क्वेरी निर्दिष्ट नहीं है, तो यह विधि संग्रह में पहला दस्तावेज़ हटा देती है।

उदाहरण

पायथन उदाहरण के बाद संग्रह में दस्तावेज़ को हटा दिया जाता है जिसका आईडी मान 1006 है।

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['lpaksgf']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
   {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
   {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
   {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Deleting one document
coll.delete_one({"_id" : "1006"})

#Retrieving all the records using the find() method
print("Documents in the collection after update operation: ")
for doc2 in coll.find():
   print(doc2)

उत्पादन

Data inserted ......
Documents in the collection after update operation:
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
{'_id': '1004', 'name': 'Romeo', 'age': 25, 'city': 'Pune'}
{'_id': '1005', 'name': 'Sarmista', 'age': 23, 'city': 'Delhi'}

इसी तरह, delete_many() pymongo की विधि उन सभी दस्तावेजों को हटा देती है जो निर्दिष्ट स्थिति को संतुष्ट करते हैं।

उदाहरण

निम्नलिखित उदाहरण संग्रह में सभी दस्तावेजों को हटा देता है जिनकी आयु मूल्य 26 से अधिक है -

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['sampleDB']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
   {"_id": "1004", "name": "Romeo", "age": "25", "city": "Pune"},
   {"_id": "1005", "name": "Sarmista", "age": "23", "city": "Delhi"},
   {"_id": "1006", "name": "Rasajna", "age": "26", "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Deleting multiple documents
coll.delete_many({"age":{"$gt":"26"}})

#Retrieving all the records using the find() method
print("Documents in the collection after update operation: ")
for doc2 in coll.find():
   print(doc2)

उत्पादन

Data inserted ......
Documents in the collection after update operation:
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1004', 'name': 'Romeo', 'age': '25', 'city': 'Pune'}
{'_id': '1005', 'name': 'Sarmista', 'age': '23', 'city': 'Delhi'}
{'_id': '1006', 'name': 'Rasajna', 'age': '26', 'city': 'Chennai'}

यदि आप डिलीट_मनी () विधि को बिना किसी प्रश्न के पास करते हैं, तो यह विधि संग्रह के सभी दस्तावेजों को हटा देती है।

coll.delete_many({})

आप संग्रह का उपयोग करके हटा सकते हैं drop() MongoDB की विधि।

वाक्य - विन्यास

निम्नलिखित ड्रॉप () विधि का वाक्य विन्यास है -

db.COLLECTION_NAME.drop()

उदाहरण

नाम नमूने के साथ उदाहरण के बाद की बूंदें संग्रह -

> show collections
myColl
sample
> db.sample.drop()
true
> show collections
myColl

अजगर का उपयोग कर संग्रह को गिराना

आप ड्रॉप () विधि द्वारा वर्तमान से संग्रह को हटा / हटा सकते हैं।

उदाहरण

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['example2']

#Creating a collection
col1 = db['collection']
col1.insert_one({"name": "Ram", "age": "26", "city": "Hyderabad"})
col2 = db['coll']
col2.insert_one({"name": "Rahim", "age": "27", "city": "Bangalore"})
col3 = db['myColl']
col3.insert_one({"name": "Robert", "age": "28", "city": "Mumbai"})
col4 = db['data']
col4.insert_one({"name": "Romeo", "age": "25", "city": "Pune"})

#List of collections
print("List of collections:")
collections = db.list_collection_names()
for coll in collections:
   print(coll)

#Dropping a collection
col1.drop()
col4.drop()
print("List of collections after dropping two of them: ")

#List of collections
collections = db.list_collection_names()
for coll in collections:
   print(coll)

उत्पादन

List of collections:
coll
data
collection
myColl
List of collections after dropping two of them:
coll
myColl

आप किसी मौजूदा दस्तावेज़ की सामग्री को अपडेट कर सकते हैं update() विधि या save() तरीका।

अपडेट विधि मौजूदा दस्तावेज़ को संशोधित करती है जबकि सेव विधि मौजूदा दस्तावेज़ को नए के साथ बदल देती है।

वाक्य - विन्यास

निम्नलिखित अद्यतन का सिंटैक्स है () और मैंगो के तरीकों को बचाओ () -

>db.COLLECTION_NAME.update(SELECTION_CRITERIA, UPDATED_DATA)
Or,
db.COLLECTION_NAME.save({_id:ObjectId(),NEW_DATA})

उदाहरण

मान लें कि हमने एक डेटाबेस में एक संग्रह बनाया है और उसमें 3 रिकॉर्ड डाले हैं जैसा कि नीचे दिखाया गया है -

> use testdatabase
switched to db testdatabase
> data = [
   ... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   ... {"_id": "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" },
   ... {"_id": "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
]
[
   {"_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad"},
   {"_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore"},
   {"_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai"}
]
> db.createCollection("sample")
{ "ok" : 1 }
> db.sample.insert(data)

निम्नलिखित विधि आईडी 1002 के साथ दस्तावेज़ के शहर मूल्य को अपडेट करती है।

>db.sample.update({"_id":"1002"},{"$set":{"city":"Visakhapatnam"}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Visakhapatnam" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }

इसी तरह आप दस्तावेज़ को नए डेटा के साथ सेव ()) विधि का उपयोग करके उसी आईडी से बदल सकते हैं।

> db.sample.save({ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Vijayawada" })
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Vijayawada" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Visakhapatnam" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }

अजगर का उपयोग कर दस्तावेजों को अद्यतन करना

Find_one () विधि के समान जो एकल दस्तावेज़ को पुनः प्राप्त करता है, pymongo का update_one () विधि एकल दस्तावेज़ को अद्यतन करता है।

यह विधि एक क्वेरी को निर्दिष्ट करती है जो यह निर्दिष्ट करती है कि किस दस्तावेज़ को अपडेट करना है और अपडेट ऑपरेशन।

उदाहरण

अजगर उदाहरण के बाद एक संग्रह में एक दस्तावेज़ के स्थान मूल्य को अद्यतन करता है।

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['myDB']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Retrieving all the records using the find() method
print("Documents in the collection: ")
for doc1 in coll.find():
   print(doc1)
coll.update_one({"_id":"102"},{"$set":{"city":"Visakhapatnam"}})

#Retrieving all the records using the find() method
print("Documents in the collection after update operation: ")
for doc2 in coll.find():
   print(doc2)

उत्पादन

Data inserted ......
Documents in the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Documents in the collection after update operation:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Visakhapatnam'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}

इसी तरह, update_many() pymongo की विधि उन सभी दस्तावेजों को अपडेट करती है जो निर्दिष्ट स्थिति को संतुष्ट करते हैं।

उदाहरण

उदाहरण के बाद एक संग्रह में सभी दस्तावेजों में स्थान का मूल्य अद्यतन करता है (खाली स्थिति) -

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['myDB']

#Creating a collection
coll = db['example']

#Inserting document into a collection
data = [
   {"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Retrieving all the records using the find() method
print("Documents in the collection: ")
for doc1 in coll.find():
   print(doc1)
coll.update_many({},{"$set":{"city":"Visakhapatnam"}})

#Retrieving all the records using the find() method
print("Documents in the collection after update operation: ")
for doc2 in coll.find():
   print(doc2)

उत्पादन

Data inserted ......
Documents in the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Documents in the collection after update operation:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Visakhapatnam'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Visakhapatnam'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Visakhapatnam'}

किसी संग्रह की सामग्री को पुनर्प्राप्त करते समय आप परिणाम () विधि का उपयोग करके दस्तावेजों की संख्या को सीमित कर सकते हैं। यह विधि कई मानों को स्वीकार करती है जो परिणाम में आपके वांछित दस्तावेजों की संख्या का प्रतिनिधित्व करते हैं।

वाक्य - विन्यास

निम्नलिखित सीमा () विधि का वाक्य विन्यास है -

>db.COLLECTION_NAME.find().limit(NUMBER)

उदाहरण

मान लें कि हमने एक संग्रह बनाया है और उसमें 5 दस्तावेज़ डाले हैं जैसा कि नीचे दिखाया गया है -

> use testDB
switched to db testDB
> db.createCollection("sample")
{ "ok" : 1 }
> data = [
   ... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   ... {"_id": "1002", "name": "Rahim", "age": 27, "city": "Bangalore"},
   ... {"_id": "1003", "name": "Robert", "age": 28, "city": "Mumbai"},
   ... {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
   ... {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
   ... {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
> db.sample.insert(data)
BulkWriteResult({
   "writeErrors" : [ ],
   "writeConcernErrors" : [ ],
   "nInserted" : 6,
   "nUpserted" : 0,
   "nMatched" : 0,
   "nModified" : 0,
   "nRemoved" : 0,
   "upserted" : [ ]
})

निम्नलिखित पंक्ति संग्रह के पहले 3 दस्तावेजों को पुनः प्राप्त करती है।

> db.sample.find().limit(3)
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }

पायथन का उपयोग करके दस्तावेजों को सीमित करना

एक प्रश्न के परिणामों को प्रतिबंधित करने के लिए एक विशेष संख्या में दस्तावेजों के लिए pymongo प्रदान करता है limit()तरीका। इस पद्धति के लिए परिणाम में आपके द्वारा आवश्यक दस्तावेजों की संख्या का प्रतिनिधित्व करने वाला एक संख्या मान पास करें।

उदाहरण

निम्नलिखित उदाहरण एक संग्रह में पहले तीन दस्तावेजों को पुनः प्राप्त करता है।

from pymongo import MongoClient

#Creating a pymongo client
client = MongoClient('localhost', 27017)

#Getting the database instance
db = client['l']

#Creating a collection
coll = db['myColl']

#Inserting document into a collection
data = [
   {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
   {"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
   {"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
   {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
   {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
   {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")

#Retrieving first 3 documents using the find() and limit() methods
print("First 3 documents in the collection: ")
for doc1 in coll.find().limit(3):
   print(doc1)

उत्पादन

Data inserted ......
First 3 documents in the collection:
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}