python - Django Save 消灭新的一对一关系?

标签 python django object save

我试图在 Django 中保存一对一关系,但在我保存 Address 对象后,它删除了我试图创建关系的对象上的关系。

在这种情况下,我试图在我的数据库中已经存在的“Person”对象和我正在​​创建的“Address”对象之间建立关系。我可以将 Person 的地址属性分配给新地址,它会在保存之前显示出来。但是,在人保存之后,人的地址对象就消失了。我检查以确保我在设置文件中具有正确的 MySQL 权限,并且我可以做我需要做的一切来保存一个新对象。在数据库中,有一个新的地址条目,但在 Person 表中没有与该人员条目关联的地址。我做错了什么?

if person.address == None:
    person.address = managerModels.Addresses()
person.address.zipCode = newAttributeValue # set up zip code
print("Address pre-save {}".format(person.address))
person.address.save()
print("Address post-address save: {}".format(person.address))
person.save()
print("Address post person-save: {} ".format(person.address))

终端的输出是

Address pre-save None None None None 94536
Address post-address save: None None None None 94536
Address post person-save: None

以下是在 models.py 文件中声明模型的方式。

class Person(models.Model):

    userId = models.OneToOneField( settings.AUTH_USER_MODEL, verbose_name = "User account", on_delete=models.DO_NOTHING, null = True)
    firstName = models.CharField(max_length=40)
    lastName = models.CharField(max_length=40)
    phone = models.CharField("Phone Number", max_length=12)
    address = models.OneToOneField(Addresses, verbose_name = "Address", on_delete=models.DO_NOTHING, null=True)
    tutorType = models.CharField("Category", max_length=12)
    gender = models.CharField("Gender", max_length=6)
    subjects = models.CharField("Subjects", max_length = 256)
    email = models.CharField("Email", max_length = 45, blank = True)
    active = models.BooleanField(default = True)


    class Meta:
        ordering = ('userId', 'firstName', 'lastName', 'phone','tutorType', 'gender', 'subjects')
        db_table = 'Persons'

    def __str__(self):
        return "\n{} {}\nPhone: {}\nAddress:{}\ntutorType: {}\nGender: {}\nsubjects: {}\nemail: {}\nactive {}".format(self.firstName,self.lastName, self.phone, self.address, self.tutorType, self.gender, self.subjects, self.email, self.active)


class Addresses(models.Model):
    address1 = models.CharField("Address Line 1", max_length=128, null=True)
    address2 = models.CharField("Address Line 2", max_length=128, null=True)
    city = models.CharField("City", max_length=64, null=True)
    state = models.CharField("State", max_length=64, null = True)
    zipCode = models.CharField("Zip Code", max_length=5, null = True)

    class Meta:
        ordering = ('address1', 'address2', 'city', 'state','zipCode')
        db_table = 'Addresses'
    def __str__(self):
        return "{} {} {} {} {}".format(self.address1, self.address2, self.city, self.state, self.zipCode)

Person 和 address 之间是一对一的关系。我在做什么,有什么明显的错误吗?我已经将这个问题缩小到这几行代码,但我仍然卡住了。有什么建议吗?

编辑:我已经更新了代码,因此我只处理个人地址的一个实例,但是对个人的保存会清除地址数据。仍然不知道出了什么问题。

最佳答案

在将 Address 对象添加到 Person 实例之前,您应该保存它。像这样:

address = managerModels.Addresses() # create a new address
address.zipCode = newAttributeValue # set up zip code
address.save()

person.address = address
person.save()

关于python - Django Save 消灭新的一对一关系?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54696750/

相关文章:

python - SQLAlchemy with_for_update 读取陈旧数据

python - Pandas groupby : *full* join result of groupwise operation on original index

python - Django 设置

java - 将序列化对象写入文件

python - 以 Pandas Dataframe 作为值的字典的 JSON 格式

python - 试图制作程序来格式化化学方程式

python - DRF - 设置序列化程序字段的最大值和最小值

表单中的 django 表单集/表单中的动态数组

c++ - 为什么编译器认为我的对象声明是函数声明?

javascript - 使用过滤功能从另一个对象创建对象