TurboGears - MongoDB का उपयोग करना
TurboGears भी MongoDB दस्तावेज़ डेटाबेस का समर्थन करता है। यह मिंग, एक ऑब्जेक्ट दस्तावेज़ मैपर एपीआई का उपयोग करता है। मिंग का उपयोग SQLAlchemy के समान है। मिंग क्वेरी भाषा ने SQLAlchemy आधारित TurboGears प्रोजेक्ट को मिंग में पोर्ट करना संभव बनाता है।
PyMongo क्या है
PyMongo एक पायथन वितरण है जिसमें MongoDB के साथ काम करने के लिए उपकरण हैं। मिंग प्रदान करता है PyMongo प्रदान करता है -
- घोषणात्मक मॉडल
- स्कीम मान्यता और रूपांतरण
- स्कीमा विकास
- शुद्ध InMemory MongoDB कार्यान्वयन
- कार्य की इकाई
- पहचान मानचित्र
- एक-से-कई, कई-से-एक और कई-कई रिश्ते
सबसे पहले, आपको MongoDB डाउनलोड और इंस्टॉल करना होगा। MongoDB का नवीनतम वितरण इससे डाउनलोड किया जा सकता हैhttps://www.mongodb.org/downloads
Windows पर, -bbath विकल्प प्रदान करके MongoDB सर्वर शुरू करें -
C:\mongodb\bin>Mongod --dbpath d:\mongo
D:\mongo folderMongoDB डेटाबेस को संग्रहीत करने के लिए निर्दिष्ट है। सर्वर पर सुनना शुरू कर देता हैhttp://localhost:27017. अब MongoDB शेल शुरू करने के लिए निम्नलिखित कमांड का उपयोग करें -
C:\mongodb\bin>Mongo
अब हमारा MongoDB वातावरण तैयार है।
अब एक TurboGears प्रोजेक्ट बनाएं -ming विकल्प के साथ -
gearbox quickstart --ming Hello
यह त्वरित परियोजना SQLAlchemy संस्करण के लिए प्रदान की गई की तरह एक प्रमाणीकरण और प्राधिकरण परत प्रदान करेगी। यह एप्लिकेशन अब स्थानीय मशीन पर पोर्ट 27017 पर एक सर्वर से कनेक्ट करने का प्रयास करेगा। प्रोजेक्ट फ़ोल्डर में development.ini फ़ाइल में निम्न सेटिंग्स हैं -
ming.url = mongodb://localhost:27017/
ming.db = hello
निम्नलिखित कमांड का उपयोग करके परियोजना को सेट करें -
Python setup.py develop
प्रोजेक्ट फ़ोल्डर में मॉडल सबफ़ोल्डर होते हैं जिनमें निम्नलिखित फाइलें होती हैं -
__init__.py - यह वह जगह है जहाँ databaseपहुंच स्थापित की गई है। आपका संग्रह होना चाहिएimported into this module। उदाहरण के लिए, हम इस पैकेज में छात्र संग्रह जोड़ेंगे।
session.py - यह फ़ाइल को परिभाषित करता है session of your database connection। जब भी आपको कोई घोषणा करनी हो, तो आपको हर बार यह आयात करना होगाMappedClass को सत्र निर्दिष्ट करना perform queries।
auth.py - यह फाइल बनाई जाएगी, अगर आपके पास है enabled authentication and authorizationजल्दी में। यह तीन संग्रहों को परिभाषित करता हैrepoze.who, जो आगे निर्भर करता है: उपयोगकर्ता, समूह और अनुमति।
अपने संग्रह को परिभाषित करना
डिफ़ॉल्ट रूप से, TurboGears मिंग को एक घोषणात्मक मोड में कॉन्फ़िगर करता है। यह SQLAlchemy घोषणात्मक समर्थन के समान है और MappedClass वर्ग से इनहेरिट करने के लिए प्रत्येक मॉडल की आवश्यकता है।
मैप्डक्लास को आवश्यकता है कि एक __mongometa__ उपवर्ग अंदर उपलब्ध हो, जो आगे दस्तावेजों को संग्रहीत करने वाले संग्रह के नाम और दस्तावेजों को संग्रहीत करने के लिए उपयोग किए जाने वाले सत्र के बारे में विवरण प्रदान करता है।
मैप्डक्लास में दस्तावेज़ में फ़ील्ड की परिभाषा भी शामिल है। मिंग के ओड्म मॉड्यूल में विभिन्न प्रकार के क्षेत्र गुण हैं -
- FieldProperty
- ForeignIdProperty
- RelationProperty
ming.schema module निम्न डेटा प्रकारों को परिभाषित करता है -
- ming.schema.Anything
- ming.schema.Array
- ming.schema.Binary
- ming.schema.Bool
- ming.schema.Float
- ming.schema.Int
- ming.schema.ObjectId
- ming.schema.Scalar
- ming.schema.String
इस मॉडल में छात्र संग्रह को जोड़ने के लिए, निम्न कोड को छात्र / छात्रावास के हेल्लो के रूप में सहेजें।
नमस्कार \ मॉडल \ student.py
from ming import schema
from ming.odm import MappedClass
from ming.odm import FieldProperty, ForeignIdProperty
from hello.model import DBSession
Class student(MappedClass):
class __mongometa__:
session = DBSession
name = 'student'
_id = FieldProperty(schema.ObjectId)
name = FieldProperty(schema.String(required = True))
city = FieldProperty(schema.String(if_missing = ''))
address = FieldProperty(schema.String(if_missing = ''))
pincode = FieldProperty(schema.String(if_missing = ''))
अंत में, इस मॉडल को हैलो \ मॉडल \ __ init__.py में शामिल करें
# Import your model modules here.
from hello.model.auth import User, Group, Permission
from hello.model.student import student
इन मॉडलों को स्थापित करने के लिए, निम्नलिखित गियरबॉक्स कमांड चलाएं -
Gearbox setup-app
निम्नलिखित गियरबॉक्स कमांड के साथ सर्वर शुरू करें -
Gearbox serve –reload –debug
इस एप्लिकेशन का होमपेज खोलें (http://localhost:8080/)और प्रबंधक क्रेडेंशियल के साथ लॉगिन करें। इस एप्लिकेशन का व्यवस्थापक पृष्ठ सेट किए गए मॉडल की सूची दिखाएगा। (प्रबंधक, पासवर्ड प्रबंधन के रूप में लॉगिन करें)
संग्रह के निर्माण को MongoDB वेब इंटरफ़ेस के साथ-साथ MongoDB शेल में भी सत्यापित किया जा सकता है।
ODMSession का उपयोग निम्नलिखित कार्यों का उपयोग करके कई डेटाबेस संचालन करने के लिए किया जाता है -
- model.query.find()
- model.query.find_and_modify()
- model.remove()
- model.update()
- model.flush()
ToscoWidget फ़ॉर्म डिज़ाइन करना
अब हम छात्र डेटा दर्ज करने के लिए एक ToscoWidget फ़ॉर्म डिज़ाइन करेंगे और इसे छात्र मॉडल की अंतर्निहित तालिका में जोड़ेंगे।
निम्नलिखित एक studentform.py बनाने के लिए कोड है -
नमस्कार \ नियंत्रकों \ studentform.py
import tw2.core as twc
import tw2.forms as twf
class StudentForm(twf.Form):
class child(twf.TableLayout):
name = twf.TextField(size = 20)
city = twf.TextField()
address = twf.TextArea("",rows = 5, cols = 30)
pincode = twf.NumberField()
action = '/save_record'
submit = twf.SubmitButton(value = 'Submit')
एप्लिकेशन के रूटकंट्रोलर '/ ऐड' URL में ऐड () फ़ंक्शन को कॉल करता है, जो ब्राउज़र में उपरोक्त डिज़ाइन किए गए फॉर्म को खोल देगा। इसका सबमिट बटन तब save_record () फ़ंक्शन को आमंत्रित करता है। यह प्रपत्र डेटा को पुनर्प्राप्त करता है और इसे छात्र तालिका में सहेजता है और एप्लिकेशन को '/ listrec' URL पर पुनर्निर्देशित करता है, जो छात्र सूची को उजागर करता है।
इस गतिविधि के लिए root.py इस प्रकार है -
हैलो / नियंत्रक / root.py
from hello.lib.base import BaseController
from tg import expose, flash, redirect, request,url, lurl
from tg import redirect, validate
from hello import model
from hello.model import DBSession
from hello.model.student import student
from hello.controllers.studentform import StudentForm
class RootController(BaseController):
@expose()
def index(self):
return "<h1>Hello World</h1>"
@expose ("hello.templates.studentlist")
def listrec(self):
entries = student.query.find()
return dict(entries = entries)
@expose('hello.templates.studentform')
def add(self, *args, **kw):
return dict(page = 'studentform', form = StudentForm)
@expose()
def save_record(self, **kw):
newstudent = student(name = kw['name'],city = kw['city'],
address = kw['address'], pincode = kw['pincode'])
DBSession.flush()
flash(message = "new entry added successfully")
redirect("/listrec")
निम्नलिखित टेम्पलेट टेम्पलेट फ़ोल्डर में बनाए गए हैं -
नमस्कार \ टेम्पलेट्स \ studentform.html
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:py = "http://genshi.edgewall.org/" lang = "en">
<head>
<title>Student Registration Form</title>
</head>
<body>
<div id = "getting_started">
${form.display(value = dict(title = 'Enter data'))}
</div>
</body>
</html>
नमस्कार \ टेम्पलेट्स \ studentlist.html
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:py = "http://genshi.edgewall.org/">
<head>
<link rel = "stylesheet" type = "text/css" media = "screen"
href = ${tg.url('/css/style.css')}" />
<title>Welcome to TurboGears</title>
</head>
<body>
<h1>Welcome to TurboGears</h1>
<py:with vars = "flash = tg.flash_obj.render('flash', use_js = False)">
<div py:if = "flash" py:replace = "Markup(flash)" />
</py:with>
<h2>Current Entries</h2>
<table border = '1'>
<thead>
<tr>
<th>Name</th>
<th>City</th>
<th>Address</th>
<th>Pincode</th>
</tr>
</thead>
<tbody>
<py:for each = "entry in entries">
<tr>
<td>${entry.name}</td>
<td>${entry.city}</td>
<td>${entry.address}</td>
<td>${entry.pincode}</td>
</tr>
</py:for>
</tbody>
</table>
</body>
</html>
सर्वर को पुनरारंभ करें और दर्ज करें http://localhost:8080/add ब्राउज़र में -
हर बार जब डेटा जोड़ा जाता है और सबमिट बटन दबाया जाता है, तो वर्तमान प्रविष्टियों की सूची प्रदर्शित की जाएगी।