我正在用我的模型扩展django.contrib.auth.User
模型:
class Farmer(models.Model):
user = models.OneToOneField(get_user_model(), on_delete=models.CASCADE, related_name="farmer")
mob_phone = models.CharField(max_length=12)
我想在迁移期间创建其中一些Farmer实例,所以我有一个python-migration作业,该作业在所有其他迁移之后进行:
def create_farmers(apps, schema_editor):
db_alias = schema_editor.connection.alias
Farmer = apps.get_model("farmer", "Farmer")
User = get_user_model()
u = User.objects.using(db_alias).create(username="kek" ,password="lol")
farmer = Farmer.objects.using(db_alias).create(id=1, user=u, mob_phone="1")
我与其他所有迁移一样,在operations
部分中运行此作业:
operations = [
migrations.RunPython(create_farmers, revert_create_farmers),
]
但是Django用
在我的脸上笑ValueError: Cannot assign "<User: kek>": "Farmer.user" must be a "User" instance.
这让我感到震惊,因为u
确实是User
实例!
答案 0 :(得分:0)
我完成了迁移工作-不知道这是否合法。 无论如何,这是我的智慧。
当您在迁移操作中使用apps.get_model("<app>", "<Model>")
时,django似乎不导入确切的<Model>
,而是类似的导入。在阅读有关迁移内部类的Django源时,我得出了这个结论。在这些来源中,我找到了一个断言,该断言将我的forignKey用户类型与类型_fake.User
进行比较。当然是我真正的用户类型
django.contrib.auth.models.User
与_fake.User
不同,并且通过部分不正确的消息django:
ValueError: Cannot assign "<User: kek>": "Farmer.user" must be a "User" instance.
解决方案是从应用程序导入真实的Farmer模型-不使用apps.get_model("<app>", "<Model>")
方法