Django添加models.py的ForeignKey数据迁移后找不到,各种报错
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