前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django迁移数据库报错你遇到了吗?

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

作者头像
小闫同学啊
发布2020-03-25 11:24:57
5760
发布2020-03-25 11:24:57
举报
文章被收录于专栏:小闫笔记小闫笔记

Adventure may hurt you, but monotony will kill you.

—— 作者未知

"

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

1.环境

Django3.0.2

代码语言:javascript
复制
(django_dev) > python -m django --version
3.0.2

MySQl8.0.19

代码语言:javascript
复制
Server version: 8.0.19 MySQL Community Server - GPL

Python3.7.6

代码语言:javascript
复制
(django_dev) > python --version
Python 3.7.6

2.报错

执行命令:

代码语言:javascript
复制
(django_dev) > python manage.py makemigrations polls

报错信息如下:

代码语言:javascript
复制
django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.

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

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

代码语言:javascript
复制
(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.解决

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

代码语言:javascript
复制
django_dev/lib/python3.7/site-packages/django/db/backends/mysql/base.py

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

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

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

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

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

然后再次执行命令:

代码语言:javascript
复制
(django_dev) > python manage.py makemigrations polls
Migrations for 'polls':
  polls/migrations/0001_initial.py
    - Create model Question
    - Create model Choice
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-03-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 全栈技术精选 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.环境
  • 2.报错
  • 3.解决
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档