Django的ORM框架相當強大,只需要在每個app的models.py文件中創(chuàng)建Class即可,每個字段就是一個類的屬性
示例:
from django.db import models
from django.contrib.auth.models import AbstractUser
# 用戶信息模型
class UserProfile(AbstractUser):
mobile = models.CharField(verbose_name=u"手機號碼", max_length=20, null=True, blank=True)
gender = models.CharField(
verbose_name=u"性別", choices=(("male", u"男"), ("female", u"女")), default="male", max_length=6)
real_name = models.CharField(verbose_name=u"真實姓名", max_length=50, null=True, blank=True)
city = models.CharField(verbose_name=u"城市", max_length=20, null=True, blank=True)
introduction = models.TextField(verbose_name=u"個人介紹", null=True, blank=True)
class Meta:
verbose_name = u"用戶信息"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.username
modes.py中的類需要繼承django.db中的models.Model,這個例子中繼承了AbstractUser,這是django中用戶類的原型,因為我要使用自己的用戶模型,所以繼承了它。在默認的用戶模型中已經(jīng)有了用戶名、密碼及郵箱,所以這里并沒有設置。
數(shù)據(jù)庫中的數(shù)據(jù)類型在django中表現(xiàn)為不同的Field,常用的有CharField、TextField、FileField等。
Fields共有的屬性
這些Field共有的屬性有null、blank、unique等,當然大部分Field還可以設置為主鍵(只能設置一個)
null屬性設置為True時,數(shù)據(jù)庫中表現(xiàn)為字段可以為空;而blank設置為True時即表示這個屬性在實例化類時必須進行賦值。
unique屬性:顧名思義,設置為True后該字段不能重復
有時候需要通過多個字段判斷唯一性,可以在Meta中設置:
unique_together = ("value_1", "value_2")
primary_key屬性,主鍵,不設置也可以,不設置的話會自動生成自增的字段id
verbose_name,字段的別名,這個是在后臺顯示的
Meta
Meta中設置這個數(shù)據(jù)表的屬性,verbose_name表的別名,verbose_name_plural表的別名的復數(shù)形式。
當然如果你不希望在后臺看到“用戶信息s”這種神奇的東西的話,就將上述兩個屬性設置成一樣即可:
class Meta:
verbose_name = u"個人信息"
verbose_name_plural = verbose_name
unicode(python3中使用str)方法,設置實例的別名
CharField
CharField即對應mysql中的varchar,在這個Field中,max_length是必須設置的。
FileField & ImageField
這倆差不多是一樣的,但是ImageField會驗證文件類型是否為有效的圖片。此外,ImageField中,必須設置max_length,而FileField中max_length有默認值100。在數(shù)據(jù)庫中,并不存放文件本身,而是存放著文件的相對路徑。
因此,通常都會設置upload_to屬性,即上傳的文件保存在哪,文件將會被保存在設置的MEDIA_ROOT中,如:
upload_to='user/'
當然也可以使用自定義的動態(tài)的上傳方法
def upload_for_file(instance, filename):
return '/'.join(['233', '666', user.username, filename])
file = models.FileField(null=True, blank=True, upload_to=upload_for_file)
通常,修改文件并不會刪除原先的文件,可以在修改操作時先進行刪除
user.file.delete(save=False)
當然這樣做很麻煩,也不便維護,所以我們可以重載Class中的save方法:
def save(self, *args, **kwargs):
# delete old file when replacing by updating the file
try:
this = AttendedPerson.objects.get(id=self.id)
if this.file != self.file:
this.file.delete(save=False)
except Exception as e:
pass
super(AttendedPerson, self).save(*args, **kwargs)
此外,還有要注意的一點就是:刪除實例(數(shù)據(jù)庫中的一行)時,并不會刪除文件。
我選擇手動刪除orz