Django 连接mysql的几个坑

近期学习Django,安装过程遇到不少坑。特此记下,方便以后查看。
笔者所用的python为2.7,django 版本为1.9.

1 . No module named MYSQLdb

出现这个问题的原因是缺少MYSQL-python依赖库, 如下为解决办法:
第一种办法:

pip install MYSQL-python

不过,这个办法通常是失败的。因为本地环境通常没有编译环境所依赖的库文件,但是可以通过第二种方法解决。
第二种办法:
1. 安装mysql的python驱动。(请注意下载的版本的位数(32位/64位))下载地址
2. 安装mysql-python模块。推荐大家使用whl文件进行安装(这里仍然要注意位数(32位/64位))。MySQL_python-1.2.5-cp27-none-win_amd64.whl
命令:

 pip install wheel
 pip install 本地whl文件地址
  1. 如果不想通过whl文件安装。window用户可以使用软件安装的方式安装。
    3.1 下载软件。下载
    3.2 设置环境变量。
    安装过程中需要获取获取python的安装路径,而这个路径由于无法手动选择,可以通过执行以下代码来设置注册列表。
#
# script to register Python 2.0 or later for use with win32all
# and other extensions that require Python registry settings
#
# written by Joakim Loew for Secret Labs AB / PythonWare
#
# source:
# http://www.pythonware.com/products/works/articles/regpy20.htm
#
# modified by Valentine Gogichashvili as described in http://www.mail-archive.com/distutils-sig@python.org/msg10512.html

import sys

from _winreg import *

# tweak as necessary
version = sys.version[:3]
installpath = sys.prefix

regpath = "SOFTWARE\\Python\\Pythoncore\\%s\\" % (version)
installkey = "InstallPath"
pythonkey = "PythonPath"
pythonpath = "%s;%s\\Lib\\;%s\\DLLs\\" % (
    installpath, installpath, installpath
)


def RegisterPy():
    try:
        reg = OpenKey(HKEY_CURRENT_USER, regpath)
    except EnvironmentError as e:
        try:
            reg = CreateKey(HKEY_CURRENT_USER, regpath)
            SetValue(reg, installkey, REG_SZ, installpath)
            SetValue(reg, pythonkey, REG_SZ, pythonpath)
            CloseKey(reg)
        except:
            print "*** Unable to register!"
            return
        print "--- Python", version, "is now registered!"
        return
    if (QueryValue(reg, installkey) == installpath and
            QueryValue(reg, pythonkey) == pythonpath):
        CloseKey(reg)
        print "=== Python", version, "is already registered!"
        return
    CloseKey(reg)
    print "*** Unable to register!"
    print "*** You probably have another Python installation!"


if __name__ == "__main__":
    RegisterPy()

3.3 一切前提都准备好了。双击安装程序即可。

2. 连接MySQL8.0版本时出现Client does not support authentication protocol requested by server

解决办法:

ALTER USER ’root‘’@’‘’ocalhost‘’ IDENTIFIED WITH mysql_native_password BY ‘密码’; 
FLUSH PRIVILEGES;

3. raise ImproperlyConfigured(“Error loading MySQLdb module: %s” % e)

从错误的提示来看,似乎是配置不当的问题,但是通过debug,你会发现这个问题实际是mysql-python没有被正确安装或者安装不当。
如图:
Django引入MYSQLdb代码
在python的环境下载执行下述代码:

import MYSQLdb

可以会出现该错误:" ImportError DLL load failed: %1 不是有效的 Win32 应用程序"
这个问题实际上是mysql的python驱动的版本或者mysql-python这个库的版本的不一致的问题。
笔者在安装的mysql驱动为64位,但是mysql-python为32位。所以出现上述问题。
解决办法也很简单,统一位数即可。

参考资料:
1.Python开发中常见问题(python常见问题)
2.ImportError DLL load failed: %1 不是有效的 Win32 应用程序
3.Navicat连接MySQL8.0版本时出现Client does not support authentication protocol requested by server;报错的问题解决办法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值