django怎么判断数据库的记录是否存在

django怎么判断数据库的记录是否存在,第1张

我觉得楼上的回答好像有点问题。大家可以自行验证一下我是否正确。

用get查询的时候,查询不到内容的时候会抛出异常,同样查询结果多余1条的时候也会抛出异常。因此,不能使用get,而应该使用filter。

filer若是查询不到数据,会返回一个空的查询集,[]  type类型是:Queryset。

查询到多余一条的时候会,还是会返回一个包含多个对象的查询集。

所有用filter查询到的是否为'[ ]'来判断是否存在。

userinfo = Users.objects.filter(email = request.POST['email'])

if userinfo.exists():

    print("yes,we have this email")

else:

   print("sorry,email is not register")

另外还可以使用count()这个方法,userinfo.count() =0的话表示不存在数据,大于0的话表示存在一条或多条。

还有就是楼上的答案:if uerinfo:..........else: .......

直接从Django模型字段参考:Field.null如果True,Django存储空值NULL在数据库中。默认值是False。

需要注意的是空字符串值总是会得到存储为空字符串,而不是NULL。null=True对于非字符串字段,如整数,布尔和日期。对于这两种类型的字段,你还需要设置blank=True如果你希望允许空值的表单,为null仅影响数据库存储(见blank)。null关于基于字符串的字段

CodeGo.net,如CharField和TextField除非你有一个很好的理由。如果一个基于字符串的字段null=True,它具有“无数据”两个可能的值:NULL和空字符串。在大多数情况下,它是多余的,以有两个可能的值“没有数据”

Django的惯例是空字符串,不NULL。Field.blank如果True,该字段允许为空。默认值是False。

注意,这是比不同null。null纯粹是数据库相关的,而blank为验证相关。如果一个字段blank=True,验证在Django管理站点将允许空值条目。如果一个字段blank=False,该领域将是必需的。Field.default默认值的字段。这可以是一个值或一个可调用对象。如果调用它会在每次调用时创建一个新的对象。

难道你不明白这一切?

从文档:null如果为True,Django存储空 值NULL,在数据库中。

默认值为False。blank如果为True,则字段允许 为空白。默认值为False。default为默认值 场。

你“default“设置将用于该领域的问题应该你的代码没有明确将其设置为一个值的值。

使用“blank“表单验证目的-空白=TRUE将允许字段设置为空值

使用“null“如果你想存储一个空值”在DB空“,通常它可是首选,设置空白值设置为空字符串,或(如适用)给定字段0。

Null =

None Blank = "" Default = "" 大概是因为它得到。 空白意味着它是NOT

NULL,而是具有价值,它表示“空”为数据类型,它在一个字符串的情况下,可能是一个空字符串。对于数字可能是0。

null:

If True, Django will store empty values as NULL in the database. Default

is False.

如果为True,空值将会被存储为NULL,默认为False。

blank:

If True, the field is allowed to be blank. Default is False.

如果为True,字段允许为空,默认不允许。


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

原文地址: http://outofmemory.cn/sjk/9524082.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存