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 ब्राउज़र में -

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