Django model class Meta原理解析


Posted in Python onNovember 14, 2020

通过一个内嵌类 "class Meta" 给你的 model 定义元数据, 类似下面这样:

class Foo(models.Model):
bar = models.CharField(maxlength=30)

class Meta:
# ...

Model 元数据就是 "不是一个字段的任何数据" -- 比如排序选项, admin 选项等等.

下面是所有可能用到的 Meta 选项. 没有一个选项是必需的. 是否添加 class Meta 到你的 model 完全是可选的.

app_label

app_label这个选项只在一种情况下使用,就是你的模型类不在默认的应用程序包下的models.py文件中,这时候你需要指定你这个模型类是那个应用程序的。比如你在其他地方写了一个模型类,而这个模型类是属于myapp的,那么你这是需要指定为:

app_label='myapp'

db_table

db_table是用于指定自定义数据库表名的。Django有一套默认的按照一定规则生成数据模型对应的数据库表名,如果你想使用自定义的表名,就通过这个属性指定,比如:

table_name='my_owner_table'

若不提供该参数, Django 会使用 app_label + '_' + module_name 作为表的名字.

若你的表的名字是一个 SQL 保留字, 或包含 Python 变量名不允许的字符--特别是连字符 --没关系. Django 会自动在幕后替你将列名字和表名字用引号引起来.

db_tablespace

有些数据库有数据库表空间,比如Oracle。你可以通过db_tablespace来指定这个模型对应的数据库表放在哪个数据库表空间。

get_latest_by

由于Django的管理方法中有个lastest()方法,就是得到最近一行记录。如果你的数据模型中有 DateField 或 DateTimeField 类型的字段,你可以通过这个选项来指定lastest()是按照哪个字段进行选取的。

一个 DateField 或 DateTimeField 字段的名字. 若提供该选项, 该模块将拥有一个 get_latest() 函数以得到 "最新的" 对象(依据那个字段):

get_latest_by = "order_date"

managed

由于Django会自动根据模型类生成映射的数据库表,如果你不希望Django这么做,可以把managed的值设置为False。

默认值为True,这个选项为True时Django可以对数据库表进行 migrate或migrations、删除等操作。在这个时间Django将管理数据库中表的生命周期

如果为False的时候,不会对数据库表进行创建、删除等操作。可以用于现有表、数据库视图等,其他操作是一样的。

order_with_respect_to

这个选项一般用于多对多的关系中,它指向一个关联对象。就是说关联对象找到这个对象后它是经过排序的。指定这个属性后你会得到一个get_XXX_order()和set_XXX_order()的方法,通过它们你可以设置或者回去排序的对象。

举例来说, 如果一个 PizzaToppping 关联到一个 Pizza 对象, 这样做:

order_with_respect_to = 'pizza'

...就允许 toppings 依照相关的 pizza 来排序.

ordering

这个字段是告诉Django模型对象返回的记录结果集是按照哪个字段排序的。比如下面的代码:

ordering=['order_date']
# 按订单升序排列
ordering=['-order_date']
# 按订单降序排列,-表示降序
ordering=['?order_date']
# 随机排序,?表示随机
ordering = ['-pub_date', 'author']
# 对 pub_date 降序,然后对 author 升序

需要注意的是:不论你使用了多少个字段排序, admin 只使用第一个字段

permissions

permissions主要是为了在Django Admin管理模块下使用的,如果你设置了这个属性可以让指定的方法权限描述更清晰可读。

要创建一个对象所需要的额外的权限. 如果一个对象有 admin 设置, 则每个对象的添加,删除和改变权限会人(依据该选项)自动创建.下面这个例子指定了一个附加权限: can_deliver_pizzas:

permissions = (("can_deliver_pizzas", "Can deliver pizzas"),)

这是一个2-元素 tuple 的tuple或列表, 其中两2-元素 tuple 的格式为:(permission_code, human_readable_permission_name).

unique_together

unique_together这个选项用于:当你需要通过两个字段保持唯一性时使用。这会在 Django admin 层和数据库层同时做出限制(也就是相关的 UNIQUE 语句会被包括在 CREATE TABLE 语句中)。比如:一个Person的FirstName和LastName两者的组合必须是唯一的,那么需要这样设置:

unique_together = (("first_name", "last_name"),)

verbose_name

verbose_name的意思很简单,就是给你的模型类起一个更可读的名字:

verbose_name = "pizza"

若未提供该选项, Django 则会用一个类名字的 munged 版本来代替: CamelCase becomes camel case.

verbose_name_plural

这个选项是指定,模型的复数形式是什么,比如:

verbose_name_plural = "stories"

若未提供该选项, Django 会使用 verbose_name + "s".

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python求解平方根的方法
Mar 11 Python
详解Python的Twisted框架中reactor事件管理器的用法
May 25 Python
Django数据库表反向生成实例解析
Feb 06 Python
pandas 读取各种格式文件的方法
Jun 22 Python
使用Python的Dataframe取两列时间值相差一年的所有行方法
Jul 10 Python
python 3.6.5 安装配置方法图文教程
Sep 18 Python
Python3爬虫之自动查询天气并实现语音播报
Feb 21 Python
详解Python odoo中嵌入html简单的分页功能
May 29 Python
给Python学习者的文件读写指南(含基础与进阶)
Jan 29 Python
python 中的[:-1]和[::-1]的具体使用
Feb 13 Python
python字典与json转换的方法总结
Dec 28 Python
Python tkinter之ComboBox(下拉框)的使用简介
Feb 05 Python
详解python爬取弹幕与数据分析
Nov 14 #Python
Ubuntu权限不足无法创建文件夹解决方案
Nov 14 #Python
Python爬虫过程解析之多线程获取小米应用商店数据
Nov 14 #Python
基于Python的身份证验证识别和数据处理详解
Nov 14 #Python
Python join()函数原理及使用方法
Nov 14 #Python
详解pycharm连接远程linux服务器的虚拟环境的方法
Nov 13 #Python
利用python 下载bilibili视频
Nov 13 #Python
You might like
PHP反射API示例分享
2016/10/08 PHP
php实现简单的权限管理的示例代码
2017/08/25 PHP
Laravel框架生命周期与原理分析
2018/06/12 PHP
PHP实现字符串大小写转函数的功能实例
2019/02/06 PHP
jquery $(document).ready() 与window.onload的区别
2009/12/28 Javascript
js parsefloat parseint 转换函数
2010/01/21 Javascript
css transform 3D幻灯片特效实现步骤解读
2013/03/27 Javascript
js控制不同的时间段显示不同的css样式的实例代码
2013/11/04 Javascript
javascript匿名函数实例分析
2014/11/18 Javascript
JavaScript中的对象的extensible属性介绍
2014/12/30 Javascript
Javascript 拖拽的一些高级的应用(逐行分析代码,让你轻松了拖拽的原理)
2015/01/23 Javascript
基于JS组件实现拖动滑块验证功能(代码分享)
2016/11/18 Javascript
jQGrid Table操作列中点击【操作】按钮弹出按钮层的实现代码
2016/12/05 Javascript
node.js平台下利用cookie实现记住密码登陆(Express+Ejs+Mysql)
2017/04/26 Javascript
angularjs中使用ng-bind-html和ng-include的实例
2017/04/28 Javascript
js防刷新的倒计时代码 js倒计时代码
2017/09/06 Javascript
ElementUI Tag组件实现多标签生成的方法示例
2019/07/08 Javascript
Node.js fs模块(文件模块)创建、删除目录(文件)读取写入文件流的方法
2019/09/03 Javascript
JS如何调用WebAssembly编译出来的.wasm文件
2020/11/05 Javascript
[03:00]2014DOTA2国际邀请赛 Titan淘汰潸然泪下Ohaiyo专访
2014/07/15 DOTA
python使用pymongo操作mongo的完整步骤
2019/04/13 Python
python中matplotlib实现随鼠标滑动自动标注代码
2020/04/23 Python
如何理解Python中包的引入
2020/05/29 Python
深入浅析Python代码规范性检测
2020/07/31 Python
python 检测nginx服务邮件报警的脚本
2020/12/31 Python
英国最大的汽车交易网站:Auto Trader UK
2016/09/23 全球购物
美术毕业生求职信
2014/02/25 职场文书
电子商务助理求职自荐信
2014/04/10 职场文书
小学生评语大全
2014/04/18 职场文书
应用心理学专业求职信
2014/08/04 职场文书
2014年国庆节活动总结
2014/08/26 职场文书
2014年个人思想工作总结
2014/11/27 职场文书
优秀班组事迹材料
2014/12/24 职场文书
校园安全学习心得体会
2016/01/18 职场文书
开学第一周日记(三篇范文)
2019/08/23 职场文书
mysql实现将字符串字段转为数字排序或比大小
2022/06/14 MySQL