在centos部署python应用后访问页面,显示如下异常信息

报错环境 python=3.6,django=2.2
……
django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.
解决方法:
Django连接MySQL时默认使用MySQLdb驱动,但MySQLdb不支持Python3,因此这里将MySQL驱动设置为pymysql,使用 pip install pymysql 进行安装,然后在工程文件__init__.py添加以下代码即可。

#安装pymysql
pip install pymysql
#__init__.py
import pymysql
pymysql.install_as_MySQLdb()

第一种:
django降到2.1.4版本就OK了

第二种(仍使用django 2.2版本):

#找到Python环境下 django包,并进入到backends下的mysql文件夹
cd /opt/anaconda3/envs/envAGC_Mini/lib/python3.6/site-packages/django/db/backends/mysql
#文件列表如下

 # 找到base.py文件,注释掉 base.py 中如下部分(35/36行)
if version < (1, 3, 3):
raise ImproperlyConfigured("mysqlclient 1.3.3 or newer is required; you have %s" % Database.__version__)

此时仍会会报错,报错信息如下:

AttributeError: ‘str’ object has no attribute ‘decode’

 #找到operations.py文件(46行,版本不同行数不同哈~自个儿find一下),将decode改为encode
#linux vim 查找快捷键:?decode
if query is not None:
query = query.decode(errors='replace')
return query
#改为
if query is not None:
query = query.encode(errors='replace')
return query

修改保存之后,不再报错。

原文

最新文章

  1. Mysql数据库 - 增删改
  2. 异步编程模型(APM)模式
  3. Flex条件判断中注意事项
  4. Linux文件系统性能优化 (转)
  5. OpenStack实战(一)
  6. SoapUI Property
  7. 开发solr功能问题点
  8. JavaScript语言核心之词法结构
  9. Java DB loadBalance 设计
  10. jQuery Validate【强大的表单验证】
  11. 将图片设置给ImageView时的属性配置
  12. Jquery将&lt;a&gt;链接变为post请求
  13. 面向对象15.1String类特点
  14. Microsoft Dynamics 365 Developer Toolkit下载地址
  15. Ubuntu16.04重新安装MySQL数据库
  16. Layout-2相关代码:3列布局代码演化[一]
  17. [W3bsafe]分享一个爬SQL注入漏洞的工具
  18. Java易错题(1)
  19. js的正则表达式编程,悬赏解决下面的问题
  20. MySQL在linux上(cmake)的source code安装方法

热门文章

  1. cookie,localStorage和sessionStorage
  2. nohup - 使程序运行时不挂起, 不向 tty 输出信息
  3. sed 流编辑命令
  4. git上拉项目
  5. man lspci
  6. [原创]Laravel 基于redis队列的解析
  7. Excel: assign label to scatter chart using specific cell values
  8. JavaScript变量和字面量
  9. 事物Spring boot @Transactional
  10. 数位dp进阶(hdu2089,3652)