gpt4 book ai didi

django - BooleanField 中的 'default=True' 有什么意义

转载 作者:行者123 更新时间:2023-12-02 11:29:41 25 4
gpt4 key购买 nike

我有一个简单的问题:在我的模型中,我正在定义一个表的结构;但是,我想为 Booleanfield 设置一个默认值:own,但它似乎无法正常工作。这是我在模型中的代码:

class Books(models.Model):
title = models.CharField(max_length=100)
own = models.BooleanField(default=True)

当我在 mysql 中desc我的表时,这就是我得到的(注意,自己的默认为 Null):

enter image description here

此外,当我尝试执行以下操作时:

INSERT INTO `counters_books` (`title`) VALUES ('My Brain is Open')

我收到此错误:

ERROR 1364 (HY000): Field 'own' doesn't have a default value

附注我知道通过使用 NullBooleanField 我将能够解决问题;但是,如果除非必须为该字段指定值,否则无法插入行,那么 default 的意义何在?

最佳答案

default 不在 SQL 级别处理 - it's handled at the model level 。因此,数据库环境中的原始 SQL 查询将引发错误。在您的 Django 环境中尝试一下:

>> book_obj = Book('Harry Potter')
>> book_obj.save()

在模型级别完成后,默认值将插入到您的 SQL 数据库中

关于django - BooleanField 中的 'default=True' 有什么意义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17287473/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com