Django - मॉडल
एक मॉडल एक वर्ग है जो हमारे डीबी में तालिका या संग्रह का प्रतिनिधित्व करता है, और जहां कक्षा की प्रत्येक विशेषता तालिका या संग्रह का एक क्षेत्र है। मॉडल एप्लिकेशन / मॉडल थिंकपैड में परिभाषित किए गए हैं (हमारे उदाहरण में: myapp / model.py)
एक मॉडल बनाना
उदाहरण के तौर पर एक ड्रीम्रियल मॉडल बनाया गया है -
from django.db import models
class Dreamreal(models.Model):
website = models.CharField(max_length = 50)
mail = models.CharField(max_length = 50)
name = models.CharField(max_length = 50)
phonenumber = models.IntegerField()
class Meta:
db_table = "dreamreal"
प्रत्येक मॉडल django.db.models.Model से विरासत में मिला है।
हमारी कक्षा में 4 विशेषताएँ (3 चारफिल्ड और 1 पूर्णांक) हैं, वे तालिका क्षेत्र होंगे।
Db_table विशेषता के साथ मेटा क्लास हमें वास्तविक तालिका या संग्रह नाम को परिभाषित करने देता है। Django तालिका या संग्रह को स्वचालित रूप से नाम देता है: myapp_modelName। यह वर्ग आपको उस तालिका के नाम को मजबूर करने देगा जो आपको पसंद है।
Django.db.models में अधिक फ़ील्ड का प्रकार है, आप उनके बारे में अधिक जान सकते हैं https://docs.djangoproject.com/en/1.5/ref/models/fields/#field-types
अपना मॉडल बनाने के बाद, आपको वास्तविक डेटाबेस जेनरेट करने के लिए Django की आवश्यकता होगी -
$python manage.py syncdb
डेटा हेरफेर (CRUD)
आइए एक "क्रूडॉप्स" दृश्य बनाएं, यह देखने के लिए कि हम मॉडल पर सीआरयूडी ऑपरेशन कैसे कर सकते हैं। हमारा myapp / views.py फिर कैसा लगेगा -
myapp/views.py
from myapp.models import Dreamreal
from django.http import HttpResponse
def crudops(request):
#Creating an entry
dreamreal = Dreamreal(
website = "www.polo.com", mail = "[email protected]",
name = "sorex", phonenumber = "002376970"
)
dreamreal.save()
#Read ALL entries
objects = Dreamreal.objects.all()
res ='Printing all Dreamreal entries in the DB : <br>'
for elt in objects:
res += elt.name+"<br>"
#Read a specific entry:
sorex = Dreamreal.objects.get(name = "sorex")
res += 'Printing One entry <br>'
res += sorex.name
#Delete an entry
res += '<br> Deleting an entry <br>'
sorex.delete()
#Update
dreamreal = Dreamreal(
website = "www.polo.com", mail = "[email protected]",
name = "sorex", phonenumber = "002376970"
)
dreamreal.save()
res += 'Updating entry<br>'
dreamreal = Dreamreal.objects.get(name = 'sorex')
dreamreal.name = 'thierry'
dreamreal.save()
return HttpResponse(res)
अन्य डेटा हेरफेर
आइए अन्य जोड़तोड़ों का पता लगाएं, जो हम मॉडल पर कर सकते हैं। ध्यान दें कि सीआरयूडी संचालन हमारे मॉडल के उदाहरणों पर किया गया था, अब हम अपने मॉडल का प्रतिनिधित्व करने वाले वर्ग के साथ सीधे काम करेंगे।
आइए अंदर एक 'डेटामानिपुलेशन' दृश्य बनाएं myapp/views.py
from myapp.models import Dreamreal
from django.http import HttpResponse
def datamanipulation(request):
res = ''
#Filtering data:
qs = Dreamreal.objects.filter(name = "paul")
res += "Found : %s results<br>"%len(qs)
#Ordering results
qs = Dreamreal.objects.order_by("name")
for elt in qs:
res += elt.name + '<br>'
return HttpResponse(res)
लिंकिंग मॉडल
मॉडल को लिंक करने के 3 तरीके प्रदान करता है Django ORM -
पहला मामला जो हम यहां देखेंगे, वह है एक-से-कई रिश्ते। जैसा कि आप ऊपर दिए गए उदाहरण में देख सकते हैं, ड्रीम्रियल कंपनी की कई ऑनलाइन वेबसाइट हो सकती हैं। परिभाषित करना कि संबंध django.db.models.ForeignKey का उपयोग करके किया जाता है -
myapp/models.py
from django.db import models
class Dreamreal(models.Model):
website = models.CharField(max_length = 50)
mail = models.CharField(max_length = 50)
name = models.CharField(max_length = 50)
phonenumber = models.IntegerField()
online = models.ForeignKey('Online', default = 1)
class Meta:
db_table = "dreamreal"
class Online(models.Model):
domain = models.CharField(max_length = 30)
class Meta:
db_table = "online"
जैसा कि आप हमारे अपडेट किए गए myapp / model.py में देख सकते हैं, हमने ऑनलाइन मॉडल जोड़ा और इसे हमारे ड्रीम्रियल मॉडल से जोड़ा।
आइए देखें कि यह सब कैसे काम करता है मैनेजमेखड शेल के माध्यम से -
पहले हमारे Django खोल में परीक्षण के लिए कुछ कंपनियों (ड्रीम्रियल प्रविष्टियाँ) बनाएँ -
$python manage.py shell
>>> from myapp.models import Dreamreal, Online
>>> dr1 = Dreamreal()
>>> dr1.website = 'company1.com'
>>> dr1.name = 'company1'
>>> dr1.mail = 'contact@company1'
>>> dr1.phonenumber = '12345'
>>> dr1.save()
>>> dr2 = Dreamreal()
>>> dr1.website = 'company2.com'
>>> dr2.website = 'company2.com'
>>> dr2.name = 'company2'
>>> dr2.mail = 'contact@company2'
>>> dr2.phonenumber = '56789'
>>> dr2.save()
अब कुछ होस्ट डोमेन -
>>> on1 = Online()
>>> on1.company = dr1
>>> on1.domain = "site1.com"
>>> on2 = Online()
>>> on2.company = dr1
>>> on2.domain = "site2.com"
>>> on3 = Online()
>>> on3.domain = "site3.com"
>>> dr2 = Dreamreal.objects.all()[2]
>>> on3.company = dr2
>>> on1.save()
>>> on2.save()
>>> on3.save()
ऑनलाइन डोमेन से होस्टिंग कंपनी (ड्रीम्रियल एंट्री) की एक्सेसिंग विशेषता सरल है -
>>> on1.company.name
और अगर हम किसी कंपनी द्वारा ड्रीम्रियल में होस्ट किए गए सभी ऑनलाइन डोमेन को जानना चाहते हैं तो हम कोड का उपयोग करेंगे -
>>> dr1.online_set.all()
QuerySet प्राप्त करने के लिए, ध्यान दें कि सभी हेरफेर विधि हमने पहले देखी है (फ़िल्टर, सभी, बहिष्कृत, ऑर्डर_बाय ...)
आप फ़िल्टर करने के संचालन के लिए लिंक किए गए मॉडल विशेषताओं का उपयोग भी कर सकते हैं, मान लें कि आप उन सभी ऑनलाइन डोमेन को प्राप्त करना चाहते हैं जहां ड्रीमरियल नाम में कंपनी 'ए' शामिल है।
>>> Online.objects.filter(company__name__contains = 'company'
Note- इस तरह की क्वेरी बस SQL DB के लिए समर्थित है। यह गैर-संबंधपरक DB के लिए काम नहीं करेगा जहां जॉइन मौजूद नहीं है और दो '_' हैं।
लेकिन यह मॉडल को जोड़ने का एकमात्र तरीका नहीं है, आपके पास OneToOneField भी है, एक लिंक जो गारंटी देता है कि दो वस्तुओं के बीच का संबंध अद्वितीय है। यदि हमने ऊपर दिए गए हमारे उदाहरण में OneToOneField का उपयोग किया है, तो इसका मतलब होगा कि प्रत्येक ड्रीम्रियल प्रविष्टि के लिए केवल एक ऑनलाइन प्रविष्टि संभव है और दूसरे तरीके से।
और पिछले एक, टेबल के बीच ManyToManyField for (nn) संबंध। ध्यान दें, जो SQL आधारित DB के लिए प्रासंगिक हैं।