Django建站筆記(二)——ORM

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

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容