写的非常好,可以解决问题:

windows下:http://blog.csdn.net/wklken/article/details/7253245

linux下:http://blog.csdn.net/wklken/article/details/7271019

另外,这篇作为总体配置方案非常好:http://lbxhappy.iteye.com/blog/816074

MySQL for python编译好的版本,下载列表,:http://www.codegood.com/downloads

安装好在Ipython command line里查看:import MySQLdb

如果报错 no module则说明安装不成功。

不报错安装成功

可以调用如下命令查看mysql安装信息:

dir(MySQLdb)  查看模块成员:

['BINARY', 'Binary', 'Connect', 'Connection', 'DATE', 'DATETIME', 'DBAPISet', 'D

ataError', 'DatabaseError', 'Date', 'DateFromTicks', 'Error', 'FIELD_TYPE', 'Int

egrityError', 'InterfaceError', 'InternalError', 'MySQLError', 'NULL', 'NUMBER',

 'NotSupportedError', 'OperationalError', 'ProgrammingError', 'ROWID', 'STRING',

 'TIME', 'TIMESTAMP', 'Time', 'TimeFromTicks', 'Timestamp', 'TimestampFromTicks'

, 'Warning', '__all__', '__author__', '__builtins__', '__doc__', '__file__', '__

name__', '__package__', '__path__', '__revision__', '__version__', '_mysql', 'ap

ilevel', 'connect', 'connection', 'constants', 'debug', 'escape', 'escape_dict',

 'escape_sequence', 'escape_string', 'get_client_info', 'paramstyle', 'release',

 'result', 'server_end', 'server_init', 'string_literal', 'test_DBAPISet_set_equ

ality', 'test_DBAPISet_set_equality_membership', 'test_DBAPISet_set_inequality',

 'test_DBAPISet_set_inequality_membership', 'thread_safe', 'threadsafety', 'time

s', 'version_info']

help(MySQLdb) 查看帮助文档

print MySQLdb.version_info

print MySQLdb.__doc__

print MySQLdb._mysql

print MySQLdb.__name__

Eclipse中mysqldb找不到:

上面都是在IDLE和python command line里检查安装MySQLdb。但此时Eclipse中还是不能用,pydev 还是会报Unresolved import,找不到该模块。

Eclipse中设置PyDev加载模块:进入windows->Preferences->PyDev->Interpreter - Python

弹出对话框:

Libraies选项下:点击界面右下角按钮apply,如果Libraries 下面中没有导入MySQLdb,就自己手动点击导入,在安装路径一般都在Python27\Lib\site-packages\lib\MySQLdb。

导入成功后,切换Forced Builtins选项卡下面,手工添加 MySQLdb 字段 点击apply强制编译。

如果还是不行,在Libraries 下面自己手动添加MySQLdb的目录,再次强制编译即可。

在装wxPython2.9-win32-py27 时, import wx 使用了上述方法后仍报错,原因是在安装wx2.9时,目录为Python27\Lib\site-packages\*wxPython2.9-msi*\wx; 只要把wx越过他的上级目录,直接放在site-packages下就可以解决问题了。

MySQLdb的使用:

MySQLdb用户指南: http://mysql-python.sourceforge.net/MySQLdb.html 

MySQLdb文档: http://mysql-python.sourceforge.net/MySQLdb-1.2.2/public/MySQLdb-module.html

测试代码:

import MySQLdb

  con= MySQLdb.connect(host='ip',user='usr',passwd='****',db='****')

  cursor =con.cursor()

  sql ="select * from table_name"

  cursor.execute(sql)

  row=cursor.fetchone()

  print row

  cursor.close()

  con.close()

以下引自上面文章,是为自己记录。请到连接地址阅读。

windows环境下的:

1.      安装数据库mysql

下载地址:http://www.mysql.com/downloads/

可以顺带装个图形工具,我用的是MySQL-Front

2.      安装MySQLdb

好了,到了这一步,你有两个选择

A.     安装已编译好的版本(一分钟)

B.     从官网下,自己编译安装(介个…..半小时到半天不等,取决于你的系统环境以及RP)

若是系统32位的,有c++编译环境的,自认为RP不错的,可以选择自己编译安装,当然,遇到问题还是难免的,一步步搞还是能搞出来的

若是系统64位的,啥都木有的,建议下编译版本的,甭折腾

2.1安装已编译版本:

http://www.codegood.com/downloads

根据自己系统下载,双击安装,搞定

然后import MySQLdb,查看是否成功

我的,win7,64位,2.7版本

MySQL-python-1.2.3.win-amd64-py2.7.exe

2.2自己编译安装

话说搞现成的和自己编译差距不一一点半点的,特别是64位win7,搞死了

2.2.1安装setuptools

在安装MySQLdb之前必须安装setuptools,要不然会出现编译错误

http://pypi.python.org/pypi/setuptools

http://peak.telecommunity.com/dist/ez_setup.py 使用这个安装(64位系统必须用这个)

2.2.2安装MySQLdb

下载MySQLdb

http://sourceforge.net/projects/mysql-python/

解压后,cmd进入对应文件夹

如果32位系统且有gcc编译环境,直接

python setup.py build

2.2.3问题汇总

A. 64位系统,无法读取注册表的问题

异常信息如下:

F:\devtools\MySQL-python-1.2.3>pythonsetup.py build

Traceback (most recent call last):

File "setup.py", line 15, in <module>

metadata, options = get_config()

File "F:\devtools\MySQL-python-1.2.3\setup_windows.py", line7, in get_config

serverKey = _winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE, options[' registry_ke

y'] )

WindowsError: [Error 2] The system cannotfind the file specified

解决方法:

其实分析代码,发现只是寻找mysql的安装地址而已  修改setup_windows.py如下

注解两行,加入一行,为第一步mysql的安装位置

#serverKey = _winreg.OpenKey(_winreg.HKEY_LOCAL_MACHINE,options['registry_key'] )

#mysql_root, dummy = _winreg.QueryValueEx(serverKey,'Location')

mysql_root = r"F:\devtools\MySQL\MySQL Server 5.5"

B.没有gcc编译环境

unable to find vcvarsall.bat

解决方法:安装编译环境(一个老外的帖子)

1)  First ofall download MinGW. Youneed g++compiler and MingW make in
setup.

2)  If youinstalled MinGW for example to “C:\MinGW” then add “C:\MinGW\bin”to your PATH
in Windows.(安装路径加入环境变量)

3)  Now startyour Command Prompt and go the directory where you have your setup.py residing.

4)  Last andmost important step:

setup.py install build --compiler=mingw32

或者在setup.cfg中加入:

[build]

    compiler = mingw32

C.gcc: /Zl: No suchfile or directory错误

异常信息如下

F:\devtools\MinGW\bin\gcc.exe -mno-cygwin-mdll -O -Wall -Dversion_info=(1,2,3,'

final',0) -D__version__=1.2.3"-IF:\devtools\MySQL\MySQL Server 5.5\include" -IC

:\Python27\include -IC:\Python27\PC -c_mysql.c -o build\temp.win-amd64-2.7\Rele

ase\_mysql.o /Zl

gcc: error: /Zl: No such file or directory

error: command 'gcc' failed with exitstatus 1

参数是vc特有的编译参数,如果使用mingw的话因为是gcc所以不支持。可以在setup_windows.py中去掉

/Zl

解决方法:

修改setup_windows.py  改为空的

#extra_compile_args = [ '/Zl' ]

extra_compile_args = [ '' ]

目前就遇到这几个问题,望补充

3.  增删改查代码示例及结果(just for test)

  1. CREATE TABLE `user` (
  2. `Id` int(11) NOT NULL AUTO_INCREMENT,
  3. `name` varchar(255) DEFAULT NULL,
  4. `age` varchar(255) DEFAULT NULL,
  5. PRIMARY KEY (`Id`)
  6. ) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
  1. #-*- coding:utf-8 -*-
  2. #dbtest.py
  3. #just used for a mysql test
  4. '''''
  5. Created on 2012-2-12
  6. @author: ken
  7. '''
  8. #mysqldb
  9. import time, MySQLdb, sys
  10. #connect
  11. conn=MySQLdb.connect(host="localhost",user="root",passwd="test_pwd",db="school",charset="utf8")
  12. cursor = conn.cursor()
  13. #add
  14. sql = "insert into user(name,age) values(%s,%s)"
  15. param = ("tom",str(20))
  16. n = cursor.execute(sql,param)
  17. print n
  18. #更新
  19. sql = "update user set name=%s where Id=9001"
  20. param = ("ken")
  21. n = cursor.execute(sql,param)
  22. print n
  23. #查询
  24. n = cursor.execute("select * from user")
  25. for row in cursor.fetchall():
  26. for r in row:
  27. print r,
  28. print ""
  29. #删除
  30. sql = "delete from user where name=%s"
  31. param =("ted")
  32. n = cursor.execute(sql,param)
  33. print n
  34. cursor.close()
  35. #关闭
  36. conn.close()

python安装MySQLdb:在windows下或linux下(以及eclipse中pydev使用msqldb的配置方法)的更多相关文章

  1. windows(32位 64位)下python安装mysqldb模块

    windows(32位 64位)下python安装mysqldb模块 www.111cn.net 编辑:mengchu9 来源:转载 本文章来给各位使用在此windows系统中的python来安装一个 ...

  2. Socket程序从windows移植到linux下需要注意的

    )头文件 windows下winsock.h或winsock2.h linux下netinet/in.h(大部分都在这儿),unistd.h(close函数在这儿),sys/socket.h(在in. ...

  3. windows客户端远程访问linux下mysql方法

    windows客户端远程访问linux下mysql方法 1. 改表法.可能是你的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入mysql后,更改 &q ...

  4. 几款抓包工具在windows,mac,linux下的支持分析

    抓包工具的使用 几款抓包工具在windows,mac,linux下的支持分析 抓包工具简介 Chrome/Firefox 开发者工具: 浏览器内置,方便易用 Fiddler/Charles: 基于代理 ...

  5. 请问下./在Linux下是什么意思

    请问下./在Linux下是什么意思 http://zhidao.baidu.com/link?url=1f-80KN7cdi-7XECpwXLUn6Ps4reMBL2zB6eiDk7JliwDgW6k ...

  6. Ubuntu下QT控制台程序无法运行的解决方案以及XTerm的配置方法

    Ubuntu下QT控制台程序无法运行的解决方案以及XTerm的配置方法 最近由于老师要求要在Ubuntu下QT上进程多线程服务器的开发,虽然只是单纯的调用qt的network模块,但是为了避免麻烦,我 ...

  7. Windows下python安装MySQLdb

    安装MySQLdb需要在电脑上安装MySQL connector C,只需要这个connector就好,不需要把mysql装全. 另外,需要安装VC for python提供编译. 到官网上下载脚本进 ...

  8. windows下与linux下安装redis及redis扩展

    1.        Redis的介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15日起 ...

  9. 我将系统从Windows迁移至Linux下的点点滴滴

    一.写在最前 由于本人的技术水平有限,难免会出现错误.本文对任何一个人有帮助都是我莫大的荣幸,任何一个大神对我的点拨,我都会感激不尽. 二.技术选型 在2013年8月低的时候,公司中了XXX市场监督局 ...

随机推荐

  1. Linux下如何进入中文目录

    给Linux安装图形用户界面之后,会在工作目录中生成图片, 文档, 下载........等中文目录,以前不知道如何进入这些目录,感觉也没有必要,今天在火狐上下载了一个软件,默认在下载这个目录当中,实在 ...

  2. C#中Fun简单介绍及运用到项目中与缓存(本地缓存,Redis)结合使用

     1.简单介绍Fun C#中Fun和Action有点类似,都是一个委托方法,不同的是Func是有返回值的,而Action没有. (T)此委托封装的方法的参数类型. 备注:详情了解Fun到(https: ...

  3. Xcode8 添加PCH文件

    转自默默desire 1.)  打开你的Xcode工程. 在Supporting Files目录下,选择 File > New > File > iOS > Other > ...

  4. vue中的eventBus

    在vue2中,父子组件传递数据,父组件可以直接传递数据进子组件,而子组件通过调用父组件传递进来的方法,将自己的数据传递回去. 那兄弟组件之间,或者是兄弟组件的子组件之间如何传递呢? 当然vuex是一种 ...

  5. js简单备忘录

    <section class="myMemory"> <h3 class="f-tit">记事本</h3> <div ...

  6. Java面试17|Java基础

    Linux上配置Java基础环境: https://www.cnblogs.com/kerrycode/archive/2015/08/27/4762921.html 1.final相关 (1)fin ...

  7. ACM Least Common Multiple

    The least common multiple (LCM) of a set of positive integers is the smallest positive integer which ...

  8. 什么是 Docker

    Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目.它基于 Google 公司推出的 Go 语言实现. 项目后来加入了 Linux 基金会,遵从了 ...

  9. Dynamics CRM 本地插件注册器连CRMAn unsecured or incorrectly secured fault was received from the other party

    今天遇到个问题,在本地打开插件注册器连接到远程CRM服务器时报如下问题 但我在CRM服务器上连接注册器是可以打开的,所以不存在账号权限这类的问题了(当然我用的是超管的账号也不可能存在),最后查询得知是 ...

  10. ROS(indigo) turtlebot2 + android一些有趣应用

    ROS和Android配合使用非常有趣,这里推荐,ROSClinet,使用rosbridge让android和ROS通信: 具体参考奥斯卡的个人剧场:http://xxhong.net/ turtle ...