工具: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__文件(有两个该文件,注意需要删除的是与项目名称同名的文件夹中的该文件)
下面是我的项目文件夹
注意需要删除的是与项目名称同名的文件夹中的__pycache__文件
删除了这两个文件之后,重新执行上面的两个命令,
即python manage.py makemigrations
和python manage.py migrate
可以正常运行了。
这时发现出错原因是第一次执行迁移文件时我的models文件中定义的类名是UserInfoo,迁移完成之后我发现多打了一个o(正确的应该是UserInfo),删除了多出来的那个o,但是迁移文件中不会自动更改,所以需要删除创建成功的迁移文件,重新迁移。