Django迁移数据库报错你遇到了吗?

"

Adventure may hurt you, but monotony will kill you.


—— 作者未知

"

Django 最新版本创建应用后,迁移数据库报错怎么办?更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

1.环境

Django3.0.2

(django_dev) > python -m django --version
3.0.2

MySQl8.0.19

Server version: 8.0.19 MySQL Community Server - GPL

Python3.7.6

(django_dev) > python --version
Python 3.7.6

2.报错

执行命令:

(django_dev) > python manage.py makemigrations polls

报错信息如下:

django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.

根据提示,是数据库 MySQL 与 Django 版本不匹配,建议我们升级 mysqlclient。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

首先要说明的是,数据库 MySQL 与 Django 都是最新版本,不存在需要升级的问题。那么问题就应该出现在连接数据库的模块 PyMySQL 上了,但它也是安装的最新版:

(django_dev) > pip install --upgrade PyMySQL
Looking in indexes: https://pypi.tuna.tsinghua.edu.cn/simple
Requirement already up-to-date: PyMySQL in /Users/ethanyan/pyenv/django_dev/lib/python3.7/site-packages (0.9.3)

根据提示,该模块并无任何更新可用。

3.解决

既然外部组件并无问题,接下来核查代码层面。可以根据报错提示,进入底层代码逐个文件查找原因,最终定位到如下文件:

django_dev/lib/python3.7/site-packages/django/db/backends/mysql/base.py

django_dev 为项目的虚拟环境。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

此文件从第 35 行开始,有如下代码在作怪:

version = Database.version_info
if version < (1, 3, 13):
    raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)

原来是底层有版本校验!查看其他文件,发现此校验并无关联内容,即可以注释掉,我们进行尝试:

# version = Database.version_info
# if version < (1, 3, 13):
#     raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__)

然后再次执行命令:

(django_dev) > python manage.py makemigrations polls
Migrations for 'polls':
  polls/migrations/0001_initial.py
    - Create model Question
    - Create model Choice

执行成功。更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值