3

我正在使用 Django 和 Django Rest Framework 编写一个 REST API。我目前正在编写模型。

我有一个学生模型、一个问题模型和一个答案模型。

class Question(models.Model):
    question_text = models.CharField()


class Answer(models.Model):
    question = models.ForeignKey(Question, on_delete=models.CASCADE)
    answer_text = models.CharField()


class Student(models.Model):
    name = models.CharField()

学生应该能够为每个问题选择一个且只能选择一个答案。所以我正在考虑设计一个学生选择的答案模型——这样我就可以让学生通过一个关系来选择——就像这样:

class StudentPickedAnswer(models.Model):
    student = models.ForeignKey(Student, on_delete=models.CASCADE)
    answer = models.ForeignKey(Answer, on_delete=models.CASCADE)

我发现unique_together. class Meta但在我看来,它无法指定关系。我需要这样的东西;

class Meta:
   unique_together = ('student', 'answer__question')

我怎样才能实现学生每个答案只能选择一个问题?或者选择一个有关系的模型是一个糟糕的设计?

4

1 回答 1

1

因为您提到学生需要为问题选择答案,所以我认为您需要为您的问题选项/选择建立一个模型。然后,您可以使用 (student, question) 上的 uniquetogether 为您的学生响应模型建模

class Question(models.Model):
    question_text = models.CharField()
    options = models.ManyToManyField(QuestionOption)

class QuestionOption(models.Model):
    option_text = models.CharField(max_length=255)

class Student(models.Model):
    name = models.CharField()

class StudentResponse(models.Model):
    student = models.ForeignKey(Student)
    question = models.ForeignKey(Question)
    response_option = models.ForeignKey(QuestionOption)

    class Meta:
        unique_together = ("student", "question")

如果每个问题都需要有独特的选择,则另一种方法。这类似于 Django 文档中的投票应用教程

class Question(models.Model):
    question = models.CharField(...)

class QuestionOption(models.Model):
    question = models.ForeignKey("Question",related_name="qs_options")
    option = models.CharField(max_length=200)

    class Meta:
       # ensuring choices are not duplicated for a question.
       unique_together = ("question", "option")
于 2018-10-29T04:35:01.617 回答