1
class Categories(models.Model):
    id = models.ForeignKey('auth.User',primary_key=True)
    name = models.CharField(max_length=100)
    description = models.CharField(max_length=300)

    def __str__(self):
        return Categories.name

    class Meta:
        order_with_respect_to = 'id'


class Specializations(models.Model):
    id = models.ForeignKey('auth.User',primary_key=True)
    name = models.CharField(max_length=100)
    description = models.CharField(max_length=300)
    categories = models.ForeignKey(Categories, on_delete=models.CASCADE)


    def __str__(self):
        return Specializations.name

course.Categories.id: (fields.W342) 在 ForeignKey 上设置 unique=True 与使用 OneTo OneField 的效果相同。

    HINT: ForeignKey(unique=True) is usually better served by a OneToOneField.

course.Courses.id: (fields.W342) 在 ForeignKey 上设置 unique=True 与使用 OneToOne 字段的效果相同。

    HINT: ForeignKey(unique=True) is usually better served by a OneToOneField.

course.Specializations.id: (fields.W342) 在 ForeignKey 上设置 unique=True 与使用 OneToOneField 的效果相同。

尽管关系是一对多,但会引发此警告或错误!不是一对一

4

1 回答 1

4

您设计模型的方式本质上是一种OneToOne关系,因为您将 设置ForeignKeyprimary_key(这会自动适用unique=True)。

您真的希望用户成为primary_keyorCategoriesSpecializations

我想你想要这样的东西:

class Categories(models.Model):
    user = models.ForeignKey('auth.User')
    name = models.CharField(max_length=100)
    description = models.CharField(max_length=300)

    def __str__(self):
        return self.name


class Specializations(models.Model):
    user = models.ForeignKey('auth.User')
    name = models.CharField(max_length=100)
    description = models.CharField(max_length=300)
    categories = models.ForeignKey(Categories, on_delete=models.CASCADE)


    def __str__(self):
        return self.name

有了这个,User可以有很多CategoriesSpecializations 我也将__str__方法更改为self.name

于 2016-02-23T19:17:46.577 回答