Django 使用sqllite3数据库运行项目OperationalError: no such table: entries 错误解决

工具:python3.7,django 2.2.6,pycharm专业版2019.2.4,python自带sqllite3数据库
刚开始学习django,看一个博客学习,照着上面的过程敲代码,
使用python自带的sqllite3数据库,执行了

python manage.py makemigrations

正常执行,之后执行

python manage.py migrate

正常执行,但是在pycharm中点击运行后报错,显示OperationalError: no such table: xxx,最后在一篇博客中找到类似问题,该博客指出了解决方法,但是没有明确指出需要删除的文件位置,我来补充一下细节。

该错误本质上是因为迁移数据库错误,所以正确的做法是删除数据库,删除pycache文件夹,然后重新迁移。
附上我的项目目录图和文件夹图(项目名称为my_site,项目应用名称为login)
删除db文件和__pycache__文件(有两个该文件,注意需要删除的是与项目名称同名的文件夹中的该文件)
Django 使用sqllite3数据库运行项目OperationalError: no such table: entries 错误解决_第1张图片
下面是我的项目文件夹
Django 使用sqllite3数据库运行项目OperationalError: no such table: entries 错误解决_第2张图片
注意需要删除的是与项目名称同名的文件夹中的__pycache__文件
Django 使用sqllite3数据库运行项目OperationalError: no such table: entries 错误解决_第3张图片
删除了这两个文件之后,重新执行上面的两个命令,
python manage.py makemigrations
python manage.py migrate
可以正常运行了。
这时发现出错原因是第一次执行迁移文件时我的models文件中定义的类名是UserInfoo,迁移完成之后我发现多打了一个o(正确的应该是UserInfo),删除了多出来的那个o,但是迁移文件中不会自动更改,所以需要删除创建成功的迁移文件,重新迁移。

你可能感兴趣的:(Django)