Django Meta內部類選項

鴨脖發表於2012-05-08

Django 模型類的Meta是一個內部類,它用於定義一些Django模型類的行為特性。以下對此作一總結:

  • abstract
     這個屬性是定義當前的模型類是不是一個抽象類。所謂抽象類是不會對應資料庫表的。一般我們用它來歸納一些公共屬性欄位,然後繼承它的子類可以繼承這些欄位。比如下面的程式碼中Human是一個抽象類,Employee是一個繼承了Human的子類,那麼在執行syncdb命令時,不會生成Human表,但是會生成一個Employee表,它包含了Human中繼承來的欄位,以後如果再新增一個Customer模型類,它可以同樣繼承Human的公共屬性:
class Human(models.Model):
    name=models.CharField(max_length=100)
    GENDER_CHOICE=((u'M',u'Male'),(u'F',u'Female'),)
    gender=models.CharField(max_length=2,choices=GENDER_CHOICE,null=True)
    class Meta:
        abstract=True
class Employee(Human):
    joint_date=models.DateField()
class Customer(Human):
    first_name=models.CharField(max_length=100)
    birth_day=models.DateField()

上面的程式碼,執行python manage.py syncdb 後的輸出結果入下,可以看出Human表並沒有被建立:

$ python manage.py syncdb
Creating tables ...
Creating table myapp_employee
Creating table myapp_customer
Installing custom SQL ...
Installing indexes ...
No fixtures found.
  • app_label


app_label這個選項只在一種情況下使用,就是你的模型類不在預設的應用程式包下的models.py檔案中,這時候你需要指定你這個模型類是那個應用程式的。比如你在其他地方寫了一個模型類,而這個模型類是屬於myapp的,那麼你這是需要指定為:
app_label='myapp'
  • db_table

db_table是用於指定自定義資料庫表名的。Django有一套預設的按照一定規則生成資料模型對應的資料庫表名,如果你想使用自定義的表名,就通過這個屬性指定,比如:
table_name='my_owner_table'
  • db_tablespace

有些資料庫有資料庫表空間,比如Oracle。你可以通過db_tablespace來指定這個模型對應的資料庫表放在哪個資料庫表空間。
  • get_latest_by

由於Django的管理方法中有個lastest()方法,就是得到最近一行記錄。如果你的資料模型中有 DateField 或 DateTimeField 型別的欄位,你可以通過這個選項來指定lastest()是按照哪個欄位進行選取的。
  • managed

由於Django會自動根據模型類生成對映的資料庫表,如果你不希望Django這麼做,可以把managed的值設定為False。
  • order_with_respect_to

這個選項一般用於多對多的關係中,它指向一個關聯物件。就是說關聯物件找到這個物件後它是經過排序的。指定這個屬性後你會得到一個get_XXX_order()和set_XXX_order()的方法,通過它們你可以設定或者回去排序的物件。
  • ordering

這個欄位是告訴Django模型物件返回的記錄結果集是按照哪個欄位排序的。比如下面的程式碼:
ordering=['order_date'] # 按訂單升序排列
ordering=['-order_date'] # 按訂單降序排列,-表示降序
ordering=['?order_date'] # 隨機排序,?表示隨機
  • permissions

permissions主要是為了在Django Admin管理模組下使用的,如果你設定了這個屬性可以讓指定的方法許可權描述更清晰可讀。
  • proxy

這是為了實現代理模型使用的,這裡先不講隨後的文章介紹。
  • unique_together

unique_together這個選項用於:當你需要通過兩個欄位保持唯一性時使用。比如假設你希望,一個Person的FirstName和LastName兩者的組合必須是唯一的,那麼需要這樣設定:
unique_together = (("first_name", "last_name"),)
  • verbose_name

verbose_name的意思很簡單,就是給你的模型類起一個更可讀的名字:
verbose_name = "pizza"
  • verbose_name_plural

這個選項是指定,模型的複數形式是什麼,比如:

verbose_name_plural = "stories"

如果不指定Django會自動在模型名稱後加一個’s’

文章來源:http://www.onepub.net/2012/02/02/django-meta%E5%86%85%E9%83%A8%E7%B1%BB%E9%80%89%E9%A1%B9/


相關文章