Meta选项
在模型类内部定义Meta类(可选的,所有选项都不是必须的),可以配置模型的元数据,
例如:
1、如排序选项(ordering)
2、数据库表名(db_table)
3、人类可读的单复数名称(verbose_name 和verbose_name_plural)。
from django.db import models
class Person(models.Model):
PRIORITY_CHOICES = [
(0,'admin'),
(1,'user'),
(2,'visitor'),
]
id=models.AutoField(primary_key=True)
name=models.CharField(max_length=30,null=True)
priority=models.IntegerField(choices=PRIORITY_CHOICES)
create_time=models.DateTimeField(auto_now_add=True)
class Meta:
# 数据库中生成的表名称 默认 app名称 + 下划线 + 类名
db_table='my_table'
# 联合索引
index_together = [
("priority", "create_time"),
]
# 建立联合索引推荐使用下面这种
indexes = [
models.Index(fields=["priority", "create_time"]), # 联合索引
models.Index(fields=['priority'], name='priority_idx'), # 单独的索引
# 关于索引名称:如果没有提供name,Django将自动生成一个索引名称。 为了兼容不同的数据库,索引名称不能超过30个字符,不能以数字(0-9)或下划线(_)开头。
]
# 联合唯一索引
unique_together = (("name", "priority"),)
# 执行Person.objects.all()
# 会先按照权限priority字段降序排,权限相同则按照创建时间create_time字段升序排
ordering = ('-priority','create_time')
# 主界面的表名会默认加s,我们可以自己指定,如下
verbose_name_plural = "table1"
# admin中详情页显示的表名称
verbose_name = '表1'
# 执行Person.objects.latest()
# 会先按照权限priority字段降序排列,权限相同则按照id字段升序排列,然后取最后一个
get_latest_by=['create_time','id']
def __str__(self):
return '%s:%s:%s' %(self.name,self.priority,self.create_time)