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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值