首页 > 解决方案 > django 唯一对象(不是唯一字段)?

问题描述

如何制作一个唯一的对象(不是每个字段唯一的)

例如:

名称:本田

类别:汽车

成功

名称:本田

类别:自行车

成功

名称:本田

类别:自行车

失败,因为所有字段与另一个对象具有相同的值

如果我unique在现场使用,第二种情况将失败,因为已经创建了本田(名称)

我的代码:

class Category(models.Model):
    name = models.CharField(max_length=127,unique=True)

    def __str__(self):
        return self.name


class Brand(models.Model):
    name = models.CharField(max_length=127,unique=True)
    category = models.ForeignKey(Category,on_delete=models.CASCADE)         

    def __str__(self):
        return self.name

标签: pythondjangopostgresqldjango-2.2

解决方案


Django 提供了一个名为 unique 的 Meta 选项,它似乎满足了这个用例:

class Brand(models.Model):
    name = models.CharField(max_length=127)
    category = models.ForeignKey(Category, on_delete=models.CASCADE)

    class Meta:
        unique_together = [[“name”, “category”]]

Django 文档指出,尽管这可能已被弃用,并推荐功能更全的 UniqueConstraint 元选项

class Meta:
    constraints = [
        UniqueConstraint(fields=[“name”,”category”], name=“unique_object”)
    ]

推荐阅读