Django添加models.py的ForeignKey数据迁移后找不到,各种报错

发布时间 2023-12-14 16:42:53作者: 九尾cat

Django添加models.py的ForeignKey数据迁移后找不到,各种报错

在创建DJango项目时候,已经实现文件列表功能,在添加用户绑定文件列表功能时候,添加user作为外键关联,添加后执行数据库迁移,一直报错找不到userid

报错信息

django.db.utils.OperationalError: no such column: student_check_uploadedfile.user_id

TypeError: Field 'id' expected a number but got <SimpleLazyObject: <django.contrib.auth.models.AnonymousUser object at 0x00000
1D4F91826D0>>.

TypeError: int() argument must be a string, a bytes-like object or a number, not 'SimpleLazyObject'

 

原因分析

这种情况可能是由于数据库迁移未正确执行导致的。可以尝试手动删除数据库并重新运行迁移命令,以确保新的模式正确应用到数据库中。

首先,备份您的数据以防止丢失。然后,删除当前的数据库文件(通常是`db.sqlite3`),接着重新运行迁移命令:

 解决方案

#做好数据备份,我这边是新库无数据直接删除操作

rm db.sqlite3

#迁移数据库和表结构
python manage.py makemigrations
python manage.py migrate