问题描述
模型.py
class Bug(models.Model):
title = models.CharField(max_length=200)
creator = models.ForeignKey(User,on_delete=models.CASCADE,related_name="creator")
lead = models.ForeignKey(User,default=None,blank=True,null=True,on_delete=models.SET_NULL,related_name="lead")
contributors = models.ManyToManyField(User,related_name="contributors")
project = models.ForeignKey(Project,on_delete=models.CASCADE)
created_at = models.DateTimeField(default=timezone.Now)
last_modified = models.DateTimeField(auto_Now=True)
status = models.ForeignKey(Status,default=0)
description = models.TextField()
class Meta:
constraints = [
models.CheckConstraint(
check=(
models.Q(
abs(datetime.Now().microsecond - created_at.microsecond) > 10
)
),name="%(app_label)s_%(class)s_exact_date",)
]
当我尝试对其运行测试时,出现以下错误:
NameError: name 'created_at' is not defined
我试图强制执行一个约束,即错误的 created_at
日期要么正好是它的创建时间,要么在它创建时间的某个严格范围内。我希望在数据库级别强制执行它,因为我试图不仅从表单条目中保护数据(在这种情况下,我可以只添加一个验证器或在字段上添加 editable=false),而且还从任何其他尝试中保护数据通过 ORM 将错误的数据保存到数据库中。我还使用约束而不是验证器,因为我不想覆盖多个函数(save()、update() 等)。
系统信息: Python v3.9.0,Django v3.1.4
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)