पायथन - NoSQL डेटाबेस

जैसे-जैसे अधिक से अधिक डेटा अनस्ट्रक्चर्ड या सेमी-स्ट्रक्चर्ड के रूप में उपलब्ध होते जाते हैं, उन्हें नोस्कल डेटाबेस के माध्यम से प्रबंधित करने की आवश्यकता बढ़ती जाती है। पायथन भी उसी तरह से NoSQL डेटाबेस के साथ बातचीत कर सकता है जैसे कि रिलेशनल डेटाबेस के साथ इंटरैक्ट करता है। इस अध्याय में हम एक NoSQL डेटाबेस के रूप में MongoDB के साथ बातचीत करने के लिए अजगर का उपयोग करेंगे। यदि आप MongoDB के लिए नए हैं, तो आप इसे हमारे ट्यूटोरियल में यहाँ सीख सकते हैं ।

MongoDB से जुड़ने के लिए, अजगर एक पुस्तकालय के रूप में जाना जाता है pymongo। आप एनाकोंडा पर्यावरण से नीचे कमांड का उपयोग करके इस लाइब्रेरी को अपने अजगर के वातावरण में जोड़ सकते हैं।

conda install pymongo

यह लाइब्रेरी python को db क्लाइंट का उपयोग करके MOngoDB से कनेक्ट करने में सक्षम बनाती है। एक बार कनेक्ट होने के बाद हम विभिन्न कार्यों के लिए उपयोग किए जाने वाले db नाम का चयन करते हैं।

डेटा सम्मिलित करना

MongoDB में डेटा डालने के लिए हम सम्मिलित () विधि का उपयोग करते हैं जो डेटाबेस वातावरण में उपलब्ध है। पहले हम नीचे दिखाए गए अजगर कोड का उपयोग करते हुए db से जुड़ते हैं और फिर हम मुख्य-मूल्य जोड़े की एक श्रृंखला के रूप में दस्तावेज़ का विवरण प्रदान करते हैं।

# Import the python libraries
from pymongo import MongoClient
from pprint import pprint

# Choose the appropriate client
client = MongoClient()

# Connect to the test db 
db=client.test

# Use the employee collection
employee = db.employee
employee_details = {
    'Name': 'Raj Kumar',
    'Address': 'Sears Streer, NZ',
    'Age': '42'
}

# Use the insert method
result = employee.insert_one(employee_details)

# Query for the inserted document.
Queryresult = employee.find_one({'Age': '42'})
pprint(Queryresult)

जब हम उपरोक्त कोड निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है।

{u'Address': u'Sears Streer, NZ',
 u'Age': u'42',
 u'Name': u'Raj Kumar',
 u'_id': ObjectId('5adc5a9f84e7cd3940399f93')}

डेटा अपडेट कर रहा है

मौजूदा MongoDB डेटा को अपडेट करना सम्मिलित करने के समान है। हम अद्यतन () पद्धति का उपयोग करते हैं जो मूल mongoDB है। नीचे दिए गए कोड में हम नए की-वैल्यू पेयर के साथ मौजूदा रिकॉर्ड को बदल रहे हैं। कृपया ध्यान दें कि हम यह निर्धारित करने के लिए किस मापदंड का उपयोग कर रहे हैं कि किस रिकॉर्ड को अपडेट करना है।

# Import the python libraries
from pymongo import MongoClient
from pprint import pprint

# Choose the appropriate client
client = MongoClient()

# Connect to db
db=client.test
employee = db.employee

# Use the condition to choose the record
# and use the update method
db.employee.update_one(
        {"Age":'42'},
        {
        "$set": {
            "Name":"Srinidhi",
            "Age":'35',
            "Address":"New Omsk, WC"
        }
        }
    )

Queryresult = employee.find_one({'Age':'35'})

pprint(Queryresult)

जब हम उपरोक्त कोड निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है।

{u'Address': u'New Omsk, WC',
 u'Age': u'35',
 u'Name': u'Srinidhi',
 u'_id': ObjectId('5adc5a9f84e7cd3940399f93')}

डेटा हटाना

एक रिकॉर्ड हटाना भी सीधे आगे है जहां हम डिलीट विधि का उपयोग करते हैं। यहां हम उस स्थिति का भी उल्लेख करते हैं जिसका उपयोग हटाए जाने के लिए रिकॉर्ड चुनने के लिए किया जाता है।

# Import the python libraries
from pymongo import MongoClient
from pprint import pprint

# Choose the appropriate client
client = MongoClient()

# Connect to db
db=client.test
employee = db.employee

# Use the condition to choose the record
# and use the delete method
db.employee.delete_one({"Age":'35'})

Queryresult = employee.find_one({'Age':'35'})

pprint(Queryresult)

जब हम उपरोक्त कोड निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है।

None

इसलिए हम देखते हैं कि विशेष रिकॉर्ड db में मौजूद नहीं है।