为什么我的模型字段超出了约束范围?

问题描述

模型.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 (将#修改为@)