Windows下安装MySQLdb遇到的问题及解决方法

片头语:因为工作需要,在CentOS上搭建环境MySQL+Python+MySQLdb,个人比较习惯使用Windows系统的操作习惯,对存字符的OS暂时还不太习惯,所以,希望能在Windows系统上也搭建一个类似的环境,用于开发。
下面列举出上面需要用到的软件的下载地址:
CentOS - http://www.centos.org/    <这是CentOS的官方网站,觉得这个Linux系统作为服务器还是很不错的。>
MySQL - http://www.mysql.com/   <个人使用的MySQL的版本:mysql-essential-5.1.53-win32.msi,也许您下载的时候已经有新的版本了。>
Python - http://www.python.org/   <个人使用的Python版本:python-2.6.6.msi>
MySQLdb - http://sourceforge.net/projects/mysql-python/   <个人使用的MySQLdb版本:MySQL-python-1.2.3.tar.gz>
1、安装MySQL,基本上全是默认选项,后面的配置也基本上都是默认选项,除了额外将"添加到系统路径"(Include Bin Directory in Windows PATH)这个复选框勾上。如果你对安装MySQL不是很清楚,可以从网上搜索一下,相关的文章很多,如下:http://rangyang163.blog.163.com/ ... 758200881203744469/
2、安装Python,也基本上默认的选项,只是把安装路径稍微改了一下。Python的默认安装路径是"C:\Python26",个人习惯将其改为"C:\Program Files\Python26"
3、在安装MySQLdb之前必须安装setuptools,要不然会出现编译错误。
Setuptools - http://pypi.python.org/pypi/setuptools    <将滚动条向下拖,很快,就可以看到一串下载地址,个人使用的是:setuptools-0.6c11.win32-py2.6.exe ,这是因为我使用的Python版本是2.66>
默认安装这个工具即可...
好了,可以正式开始安装MySQLdb了,我们下载的这个tar.gz是源码包,里面是没有安装程序的,需要先编译,再安装。<其实只要看看README就明白了。>
(1)将MySQL-python-1.2.3.tar.gz解压到当前目录下,会出现一个MySQL-python-1.2.3文件夹;
(2)WIN+R,打开运行对话框,输入cmd,打开MS-DOS,进入上面解压的那个文件夹;(前提是你得明白cd是什么命令 :-)....)
(3)输入setup.py build开始编译...<额外补充一点,因为编译时需要利用VC的编译工具,如果没有安装VC不知会出现什么问题...最好把VC++和C#环境都装上,因为只装VC++还有cl.exe找不到的问题,自己配置还是有点问题的!>
我在编译过程中遇到以下问题:
1)问题 : _mysql.c(34) : fatal error C1083: Cannot open include file: ‘config-win.h’: No such file or directory
error: command ‘”C:\Program Files\Microsoft Visual Studio 9.0\VC\BIN\cl.exe”‘ failed with exit status 2
原因 :原因是安装MySQL的时候没有安装C语言库。
解决 :重新运行MySQL的安装程序,选择Modify,把“C Include Files / Lib Files”勾选上,并安装。
2)问题 :Traceback (most recent call last):
  File "setup.py", line 15, in
    metadata, options = get_config()
  File "C:\MySQL-python-1.2.3\setup_windows.py", line 7, in get_config
    serverKey = _winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE, options['registry_key'])
WindowsError: [Error 2] The system cannot find the file specified
原因 :MySQL for python 1.2.3仍然是在寻找MySQL5.0的版本
解决 :1、打开目录下site.cfg文件,修改最后一行为“registry_key = SOFTWARE\MySQL AB\MySQL Server 5.1”
2、打开setup_windows.py文件,修改第七行为“serverKey = _winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE, 'SOFTWARE\MySQL AB\MySQL Server 5.1')”
3)问题 :build\temp.win32-2.7\Release\_mysql.pyd.manifest : general error c1010070: Failed to load and parse the manifest. The system cannot find the file specified.
error: command ‘mt.exe’ failed with exit status 31
原因 :路径发生变化?
解决 :打开“你的PYTHON安装目录\Lib\distutils\msvc9compiler.py”文 件,找到“ld_args.append(’/MANIFESTFILE:’ + temp_manifest)”这行代码,将其改为“ld_args.append(’/MANIFEST’)”
(4)当编译完成以后,就可以输入setup.py install了,现在终于大功告成了!
可以在DOS环境下输入以下命令进行测试:
C:\Users\Michael>python
Python 2.6.6 (r266:84297, Aug 24 2010, 18:46:32) [MSC v.1500 32 bit (Intel)] on
win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import MySQLdb
>>>
这样就说明MySQLdb已经成功安装了!接下来,就可以学习Python+MySQLdb+MySQL了,祝你愉快

你可能感兴趣的:(python学习)