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 ( )
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.
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
- ordering
這個字段是告訴Django模型對象返回的記錄結果集是依照哪個字段排序的。比方以下的代碼:
ordering
=
[
'order_date'
]
# 按訂單升序排列
ordering = [ '-order_date' ] # 按訂單降序排列,-表示降序
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的意思非常easy。就是給你的模型類起一個更可讀的名字:
verbose_name
=
"pizza"
- verbose_name_plural
這個選項是指定。模型的復數形式是什么。比方:
verbose_name_plural = "stories"
假設你不指定Django在型號名稱加一后,自己主動’s’
版權聲明:本文博客原創文章。博客,未經同意,不得轉載。