Django中blank和NULL

Django中blank和NULL,第1张

概述当我们在django中添加一个数据库字段时,我们通常会写models.CharField(max_length = 100,null = True,blank = True)。用ForeignKey,DecimalField做同样的事情。有什么基本的区别在于 null = True only blank = True only null = True,blank = True 关于不同的(Char

当我们在django中添加一个数据库字段时,我们通常会写models.CharFIEld(max_length = 100,null = True,blank = True)。用ForeignKeyDecimalFIEld做同样的事情。有什么基本的区别在于

null = True only blank = True only null = Trueblank = True
关于不同的(CharFIEldForeignKeyManyToManyFIEldDateTimeFIEld)字段。使用1/2/3有什么优点/缺点?

在数据库中的列上设置NulL(而不是NOT NulL)。 Django字段类型(如DateTimeFIEldForeignKey)的空值将作为NulL存储在DB中。

blank = True决定了表单中是否需要该字段。这包括管理员和您自己的自定义表单。如果blank = True那么这个字段不是必需的,而如果是False,那么这个字段不能是空白的。

这两者的组合非常频繁,因为通常情况下,如果您要允许表单中的某个字段为空,则还需要您的数据库允许NulL值该领域。例外是CharFIEldTextFIEld,它们在Django中永远不会保存为NulL。空值作为空字符串存储在数据库中()。

几个例子:

models.DateTimeFIEld(blank=True) # raises IntegrityError if blankmodels.DateTimeFIEld(null=True) # NulL allowed,but must be filled out in a form

很明显,这两个选项并不合逻辑,但是如果你希望在表单中总是需要一个字段的话,那么null = True,blank = False,但通过类似shell的方式处理对象时是可选的。)

models.CharFIEld(blank=True) # No problem,blank is stored as ''models.CharFIEld(null=True) # NulL allowed,but will never be set as NulL

CHARTEXT类型从来不会被Django保存为NulL,所以null = True是不必要的。但是,您可以手动将其中一个字段设置为None,以强制将其设置为NulL。如果您有可能需要的场景,您仍然应该包含null = True

这是ORM如何映射blank& Django 1.8的null字段

class Test(models.Model):    charNull        = models.CharFIEld(max_length=10,null=True)    charBlank       = models.CharFIEld(max_length=10,blank=True)    charNullBlank   = models.CharFIEld(max_length=10,null=True,blank=True)    intNull         = models.IntegerFIEld(null=True)    intBlank        = models.IntegerFIEld(blank=True)    intNullBlank    = models.IntegerFIEld(null=True,blank=True)    dateNull        = models.DateTimeFIEld(null=True)    dateBlank       = models.DateTimeFIEld(blank=True)    dateNullBlank   = models.DateTimeFIEld(null=True,blank=True)

为 Postgresql 9.4 创建的数据库字段是:

CREATE table Test (  ID              serial                    NOT NulL,"charNull"      character varying(10),"charBlank"     character varying(10)     NOT NulL,"charNullBlank" character varying(10),"intNull"       integer,"intBlank"      integer                   NOT NulL,"intNullBlank"  integer,"dateNull"      timestamp with time zone,"dateBlank"     timestamp with time zone  NOT NulL,"dateNullBlank" timestamp with time zone,CONSTRAINT Test_pkey PRIMARY KEY (ID))

为 MysqL 5.6 创建的数据库字段是:

CREATE table Test (     `ID`            INT(11)     NOT  NulL    auto_INCREMENT,`charNull`      VARCHAR(10) NulL DEFAulT NulL,`charBlank`     VARCHAR(10) NOT  NulL,`charNullBlank` VARCHAR(10) NulL DEFAulT NulL,`intNull`       INT(11)     NulL DEFAulT NulL,`intBlank`      INT(11)     NOT  NulL,`intNullBlank`  INT(11)     NulL DEFAulT NulL,`dateNull`      DATETIME    NulL DEFAulT NulL,`dateBlank`     DATETIME    NOT  NulL,`dateNullBlank` DATETIME    NulL DEFAulT NulL)
总结

以上是内存溢出为你收集整理的Django中blank和NULL全部内容,希望文章能够帮你解决Django中blank和NULL所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1191301.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存