0

假设我有如下关系:

class Student(AbstractBaseUser):
    # It inherits AbstractBaseUser and has it's own manger
    # note: I did forget to add editable here
    id = models.UUIDField(primary_key=True, default=uuid.uuid4)
    firstname
    lastname
    ...


class Teacher(models.Model):
    id = models.UUIDField(default=uuid.uuid4, primary_key=True)
    firstname
    lastname
    email
    ...


class Meeting(models.Model):
    id = models.UUIDField(default=uuid.uuid4, primary_key=True, editable=False)
    student = models.ManyToManyField(Student)
    teacher = models.ManyToManyField(Teacher)

我应该如何为“学生”或“老师”字段添加/设置值。我试图将相关模型中的对象分配给它们,但出现错误

禁止直接分配到多对多集合的前端。使用 student.set() 代替。

我也试过这个:

m = Meeting()
s = Student.objects.first() #to get a random student
m.student.add(s)

然后我得到: ValueError: Cannot add "<Student: sarah@gmail.com>": instance is on database "None", value is on database "default"

我也这样做了:

m = Meeting.objects.create() #It does only have two mentioned fields.
m.student.add(s)

我明白了: django.db.utils.ProgrammingError: column "meeting_id" is of type bigint but expression is of type uuid LINE 1: ..._meeting" ("meeting_id", "student_id") VALUES ('c7688df9-.. . ^ 提示:您将需要重写或强制转换表达式。

4

2 回答 2

2

您创建一个然后用s 和sMeeting填充它,所以:TeacherStudent

s1 = Student.objects.create(firstname='Foo', last_name='Bar')
s2 = Student.objects.create(firstname='Qux', last_name='Qux')
t1 = Teacher.objects.create(
    firstname='Some',
    last_name='One',
    email='someone@something.com'
)

m = Meeting.objects.create()
m.student.add(s1, s2)
m.teacher.add(t1)

有关详细信息,请参阅文档的多对多关系部分

根据您在问题中共享的异常,您在创建类型主键之前Meeting创建了模型。我们可以通过以下方式解决这个问题:UUIDField

  1. 删除Meeting模型;
  2. 运行makemigrations
  3. 创建一个新Meeting模型;
  4. 再次运行makemigrations;和
  5. 运行migrate以更新数据库。
于 2021-06-08T18:14:48.620 回答
0

首先保存 Student 对象和 Teacher 对象

>> student_data = {'firstname': 'John', 'last_name', 'Doe', }
>> student1 = Student.objects.create(**student_data )
>>student_data = {'firstname': 'Test', 'last_name', 'Test', }
>> student2 = Student.objects.create(**student_data )

>> teacher_data  = {'firstname': 'TeacherJohn', 'last_name': 'TeacherDoe', 'email': 'john.doe@mail.com'}
>> teacher = Teacher.objects.create(**teacher_data )

然后使用其他字段(m2m 除外)创建一个会议对象。然后添加/设置 m2m 对象。

meeting = Meeting.objects.create(**the_model_fields_as_dict)
meeting.student.add(student1, student2)
meeting.teacher.add(teacher )
于 2021-06-08T18:28:34.780 回答