Django - Modeller

Model, DB'mizdeki tabloyu veya koleksiyonu temsil eden ve sınıfın her özniteliğinin tablo veya koleksiyonun bir alanı olduğu bir sınıftır. Modeller app / models.py dosyasında tanımlanmıştır (bizim örneğimizde: myapp / models.py)

Bir Model Oluşturmak

Aşağıda örnek olarak oluşturulmuş bir Dreamreal modeli verilmiştir -

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"

Her model django.db.models.Model'den miras alır.

Sınıfımızın 4 özelliği vardır (3 CharField ve 1 Integer), bunlar tablo alanları olacaktır.

Db_table özniteliğine sahip Meta sınıfı, gerçek tablo veya koleksiyon adını tanımlamamızı sağlar. Django tabloyu veya koleksiyonu otomatik olarak adlandırır: myapp_modelName. Bu sınıf, tablonun adını istediğiniz gibi zorlamanıza izin verecektir.

Django.db.models'te daha fazla alan türü var, bunlar hakkında daha fazla bilgi edinebilirsiniz. https://docs.djangoproject.com/en/1.5/ref/models/fields/#field-types

Modelinizi oluşturduktan sonra, gerçek veritabanını oluşturmak için Django'ya ihtiyacınız olacak -

$python manage.py syncdb

Verileri İşleme (CRUD)

Modeller üzerinde CRUD işlemlerini nasıl yapabileceğimizi görmek için bir "crudops" görünümü oluşturalım. Myapp / views.py dosyamız şöyle görünecektir -

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)

Diğer Veri Manipülasyonu

Modeller üzerinde yapabileceğimiz diğer manipülasyonları inceleyelim. CRUD işlemlerinin modelimizin örneklerinde yapıldığına dikkat edin, şimdi doğrudan modelimizi temsil eden sınıfla çalışacağız.

Şimdi bir 'datamanipulation' görünümü oluşturalım. 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)

Bağlantı Modelleri

Django ORM, modelleri bağlamanın 3 yolunu sunar -

Burada göreceğimiz ilk durumlardan biri bire çok ilişkilerdir. Yukarıdaki örnekte görebileceğiniz gibi, Dreamreal şirketinin birden fazla çevrimiçi web sitesi olabilir. Bu ilişkinin tanımlanması django.db.models.ForeignKey kullanılarak yapılır -

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"

Güncellenen myapp / models.py dosyamızda görebileceğiniz gibi, çevrimiçi modeli ekledik ve Dreamreal modelimize bağladık.

Manage.py shell ile tüm bunların nasıl çalıştığını kontrol edelim -

Öncelikle Django kabuğumuzda test etmek için bazı şirketler (Dreamreal girişleri) oluşturalım -

$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()

Şimdi bazı barındırılan alanlar -

>>> 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()

Hosting şirketinin özelliğine (Dreamreal girişi) çevrimiçi bir etki alanından erişmek basittir -

>>> on1.company.name

Dreamreal'daki bir Şirket tarafından barındırılan tüm çevrimiçi etki alanını bilmek istiyorsak, kodu kullanacağız -

>>> dr1.online_set.all()

Bir Sorgu Kümesi almak için, daha önce gördüğümüz tüm işleme yöntemlerinin (filtreleme, tümü, hariç tutma, sıralama_sayısı ....)

Filtreleme işlemleri için bağlantılı model özelliklerine de erişebilirsiniz, diyelim ki Dreamreal adında 'şirket' bulunan tüm çevrimiçi etki alanlarını almak istiyorsunuz -

>>> Online.objects.filter(company__name__contains = 'company'

Note- Bu tür bir sorgu yalnızca SQL DB için desteklenir. Bağlantıların olmadığı ve iki "_" bulunan ilişkisel olmayan DB için çalışmaz.

Ancak modelleri bağlamanın tek yolu bu değil, aynı zamanda iki nesne arasındaki ilişkinin benzersiz olduğunu garanti eden bir bağlantı olan OneToOneField'a da sahipsiniz. OneToOneField'i yukarıdaki örneğimizde kullandıysak, bu, her Dreamreal girişi için yalnızca bir Çevrimiçi girişin mümkün olduğu ve diğer şekilde mümkün olduğu anlamına gelir.

Ve sonuncusu, tablolar arasındaki (nn) ilişkisi için ManyToManyField. Unutmayın, bunlar SQL tabanlı DB ile ilgilidir.