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.