Meta 選項
通過一個內嵌類 "class Meta" 給你的 model 定義元數據, 類似下面這樣:
class Foo(models.Model):
bar = models.CharField(maxlength=30)
class Meta:
# ...
Model 元數據就是 "不是一個字段的任何數據" -- 比如排序選項, admin 選項等等.
下面是所有可能用到的 Meta 選項. 沒有一個選項是必需的. 是否添加 class Meta 到你的 model 完全是可選的.
db_table
本模塊在數據庫中對應的表的名字:
db_table = "pizza_orders"若不提供該參數, Django 會使用 app_label + '_' + module_name 作爲表的名字.
若你的表的名字是一個 SQL 保留字, 或包含 Python 變量名不允許的字符--特別是連字符 --沒關係. Django 會自動在幕後替你將列名字和表名字用引號引起來.
- get_latest_by
-
一個 DateField 或 DateTimeField 字段的名字. 若提供該選項, 該模塊將擁有一個 get_latest() 函數以得到 "最新的" 對象(依據那個字段):
get_latest_by = "order_date"
點擊 獲取最新對象 可以看到一個完整的例子.
order_with_respect_to
Options.order_with_respect_to
把給定的字段標誌爲可排序的,這個基本上都用在關係對象上根據父類排序. 例如, 一個答案關聯到一個問題, 一個問題有多個答案,對答案排序, 你可以這樣:
- class Answer(models.Model):
- question = models.ForeignKey(Question)
- # ...
- class Meta:
- order_with_respect_to = 'question'
- ordering
-
默認排序字段及排序方式, 用於得到一個對象列表的任何場合:
ordering = ['-order_date']
這是一個 tuple 或一個字符串列表. 每個字符串是一個字段名帶及一個可選的前綴 "-" , 這個前綴表示按降序排序(遞減). 若沒有這個前綴,則表示按升序排序.字符串 "?" 表示隨機排序.
舉個例子, 要對 pub_date 字段以升序排列, 這樣做:
ordering = ['pub_date']
要降序排列, 這樣:
ordering = ['-pub_date']
要對 pub_date 降序,然後對 author 升序, 這樣:
ordering = ['-pub_date', 'author']
點擊 指定排序 查看一個完整的例子. 注意一點,不論你使用了多少個字段排序, admin 只使用第一個字段.
- permissions
-
要創建一個對象所需要的額外的權限. 如果一個對象有 admin 設置, 則每個對象的添加,刪除和改變權限會人(依據該選項)自動創建.下面這個例子指定了一個附加權限: can_deliver_pizzas:
permissions = (("can_deliver_pizzas", "Can deliver pizzas"),)
這是一個2-元素 tuple 的tuple或列表, 其中兩2-元素 tuple 的格式爲:(permission_code, human_readable_permission_name). .
- unique_together
-
Sets of field names that, taken together, must be unique:
unique_together = (("driver", "restaurant"),)
這是一個字段列表的列表,這些字段的綜合值必須是唯一的. 這會在 Django admin 層和數據庫層同時做出限制(也就是相關的 UNIQUE 語句會被包括在CREATE TABLE 語句中).
- verbose_name
-
是該對象的一個可讀性更好的唯一名字:
verbose_name = "pizza"
若未提供該選項, Django 則會用一個類名字的 munged 版本來代替: CamelCase becomes camel case.
- verbose_name_plural
-
對象名字的複數:
verbose_name_plural = "stories"
若未提供該選項, Django 會使用 verbose_name + "s".