模型元数据是“任何不是字段的数据”,比如排序选项(ordering),数据库表名(db_table)或者人类可读的单复数名称(verbose_name 和verbose_name_plural)。在模型中添加class Meta是完全可选的,所有选项都不是必须的。
class Book(models.Model): name =models.CharField(max_length=32) def __str__(self): return self.name class Author(models.Model): name = models.CharField(max_length=32) m = models.ManyToManyField('Book') def __str__(self): return self.name class A_to_B(models.Model): bid = models.ForeignKey(Book) aid = models.ForeignKey(Author) class Meta: unique_together = ( ('bid','aid'), )
上面定义了3张表,一张是Book表,一张是Author表,然后定义了一个多对多关系的A_to_B表,最后定义了元数据,它的意思上面的多对多表具有唯一约束。
可用的元选项
1、abstract--抽象类
- 这个属性是定义当前的模型类是不是一个抽象类。
- 所谓抽象类是不会生成相应数据库表的。
- 一般我们用它来归纳一些公共属性字段,然后继承它的子类能够继承这些字段。
比方以下的代码中Human是一个抽象类。Employee是一个继承了Human的子类,那么在执行数据迁移命令时,不会生成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()
2、db_table--重写数据表名称
- 默认情况下,Django 会根据模型类的名称和包含它的应用的名称自动指定数据库表名称。eg:blog_type(blog:APP名称,type:模型类名称)
- 使用 Meta类中的 db_table 参数来重写数据表的名称
class Book(models.Model): name =models.CharField(max_length=32) def __str__(self): return self.name
class Meta:
db_table = "book"
3、managed--管理表的创建、删除
- 默认为True,意思是Django在migrate命令中创建合适的数据表,并且会在 flush 管理命令中移除它们。换句话说,Django会管理这些数据表的生命周期。
- 如果是False,Django 就不会为当前模型创建和删除数据表。如果当前模型表示一个已经存在的,通过其它方法建立的数据库视图或者数据表,这会相当有用。
- 当设置为managed=False时,需要注意一下几点:
- 如果你不声明它的话,会向你的模型中添加一个自增主键。为了避免给后面的代码读者带来混乱,强烈推荐你在使用未被管理的模型时,指定数据表中所有的列。
- 如果一个带有managed=False的模型含有指向其他未被管理模型的ManyToManyField,那么多对多连接的中介表也不会被创建。
- 但是,一个被管理模型和一个未被管理模型之间的中介表会被创建。
- 如果你需要修改这一默认行为,创建中介表作为显式的模型(设置为managed),并且使用ManyToManyField.through为你的自定义模型创建关联。
- 对于带有managed=False的模型的测试,你要确保在测试启动时建立正确的表。
4、ordering--排序
对象默认的顺序,获取一个对象的列表时使用:
ordering = ['-order_date']
它是一个字符串的列表或元组。每个字符串是一个字段名,前面带有可选的“-”前缀表示倒序。前面没有“-”的字段表示正序。使用"?"来表示随机排序。
- 例如,要按照pub_date字段的正序排序,这样写: ordering = ['pub_date']
- 按照pub_date字段的倒序排序,这样写: ordering = ['-pub_date']
- 先按照pub_date的倒序排序,再按照 author 的正序排序,这样写: ordering = ['-pub_date', 'author']
警告:
排序并不是没有任何代价的操作。你向ordering属性添加的每个字段都会产生你数据库的开销。你添加的每个外键也会隐式包含它的默认顺序。
5、unique_together--添加unique
用来设置的不重复的字段组合:unique_together = (("driver", "restaurant"),)
- 它是一个元组的元组,组合起来的时候必须是唯一的。
- 它在Django后台中被使用,在数据库层上约束数据(比如,在 CREATE TABLE 语句中包含 UNIQUE语句)。
为了方便起见,处理单一字段的集合时,unique_together 可以是一维的元组:
unique_together = ("driver", "restaurant")
6、index_together--添加索引
用来设置带有索引的字段组合:
index_together = [
["pub_date", "deadline"],
]
列表中的字段将会建立索引(例如,会在CREATE INDEX语句中被使用)。
为了方便起见,处理单一字段的集合时,index_together可以是一个一维的列表:index_together = ["pub_date", "deadline"]
7、verbose_name--模型类的单数名称
对象的一个易于理解的名称,为单数:
verbose_name = "pizza"
如果此项没有设置,Django会把类名拆分开来作为自述名,比如CamelCase 会变成camel case
8、verbose_name_plural--模型类的复数名称
该对象复数形式的名称:
verbose_name_plural = "stories"
如果此项没有设置,Django 会使用 verbose_name + "s"。