我经常使用 django rest 框架,直到今天一切正常。同一个函数突然返回不同的东西。我的客户模型上有一个独特的名字和公司。我最近创建了一个名为 AutoCompany 的 mixin,它会自动在客户端上设置公司。
我的客户模型:
class Client(AutoCompany):
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
name = models.CharField(max_length=155)
description = models.TextField(blank=True)
class Meta:
constraints = [
models.UniqueConstraint(fields=["name", "company"], name="Name and company"),
]
汽车公司
class AutoCompany(models.Model):
company = models.ForeignKey("company.Company", models.DO_NOTHING)
def save(self, *args, **kwargs):
company = apps.get_model("company.Company")
try:
self.company
except company.DoesNotExist:
self.company = get_request().user.company
self.after_company_set()
return super().save(*args, **kwargs)
def after_company_set(self):
pass
class Meta:
abstract = True
所以以前当我为同一家公司创建一个同名的客户时,我收到了一个 400 响应,并显示此错误:
The fields name, company must make a unique set.
我的序列化器如下所示:
class ClientSerializer(serializers.ModelSerializer):
class Meta:
model = models.Client
fields = ["id", "name", "description"]
但现在我只收到一个带有 python 错误的 500 响应。似乎不再捕获该错误。现在我得到了:
django.db.utils.IntegrityError: (1062, "Duplicate entry 'test-cafd0ed10f9f4865a1d56abb67daa831' for key 'Name and company'")
有人知道为什么会发生这种变化吗?
最佳答案
DRF 不会像 unique_together
那样验证 UniqueConstraint
。
这是因为唯一约束可能比“这个字段集合必须具有唯一值”更复杂。请考虑以下事项:
UniqueConstraint(
fields=["author", "slug"],
condition=Q(status="published"),
name="author_slug_published_uniq",
)
此约束仅在状态为 published
时验证该行是唯一的,即如果它们都是草稿,则可以有多个具有相同 slug 和作者的行。由于这种复杂性,因此没有验证器。但是,对于这种简单的情况,您可以添加 DRF's UniqueTogether
validator手动:
class ClientSerializer(serializers.ModelSerializer):
class Meta:
fields = ["id", "name", "description", "company"]
validators = [
UniqueTogetherValidator(
queryset=Client..objects.all(),
fields=["name", "company"],
)
]
关于python - Django 休息框架唯一一起错误消息不再显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62912123/