django数据库模型明明设置了default值,数据库却不能体现,为何?

class Book(models.Model):
    """图书"""
    name = models.CharField(max_length=30, verbose_name='书名')
    pub_date = models.DateField(verbose_name='发布日期')
    read = models.IntegerField(default=0, verbose_name='阅读量')
    comment = models.IntegerField(default=0, verbose_name='评论量')
    is_delete = models.BooleanField(default=False, verbose_name='逻辑删除')

    class Meta:
        db_table = 'tb_book'
        verbose_name = '图书'
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.name

如上所示,模型类中明明对read,comment,is_delete字段设置了默认值,但迁移数据库生成表后,查看数据库,竟然发现没有默认值.

django数据库模型明明设置了default值,数据库却不能体现,为何?_第1张图片

实际是这样的,虽然数据库没有增加默认值,但操作orm时,默认值会生效.

django数据库模型明明设置了default值,数据库却不能体现,为何?_第2张图片

django数据库模型明明设置了default值,数据库却不能体现,为何?_第3张图片

实际上,模型类中的限制,有些会体现在表结构中,有些却不会立即体现出来.

comment = models.CharField(max_length=100, null=True, blank=True, verbose_name='描述信息')

这个字段,在数据库中就明显体现了其作用:

django数据库模型明明设置了default值,数据库却不能体现,为何?_第4张图片

你可能感兴趣的:(Python)