python操作mysql数据库系列-安装MySQLdb

一波三折,先是pip命令出现问题,然后各种方法尝试解决。然后是直接使用pip2命令安装报错,mysql-python库安装再次出现问题。于是使用国内镜像的方式去安装:pip2 install MySQL-python -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com 这个命令去安装,总算链接上了,下载下来了,但是依然有报错。

pymongo 换成你想要安装的包,,别照搬照抄哈~~~~~~

 报错如下:

针对这个问题,我们再次寻找解决方法,报错原因是因为我们缺少了一个文件     MySQL_python-1.2.5-cp27-none-win_amd64.whl     这个文件的下载地址https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysql-python 

根据自己的操作系统版本选择下载的文件类型。我是选择的62位的。下载完成后,我们使用pip命令去安装刚刚下载的mysql文件。

再当前目录我们执行: pip2 install MySQL_python-1.2.5-cp27-none-win_amd64.whl  命令   如下图表示安装成功。

 

然后我们在去执行:pip2 install MySQL-python -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com

发现已经安装成功了。然后我们进入到python2的交互模式,执行 import  MySQLdb 发现导入成功!!!!

 方案二:直接下载  MySQLdb for python(32/64位)下载地址:http://www.codegood.com/archives/129

 在安装MySQL-python-1.2.3.win-amd64-py2.7.exe时,提示:Python version 2.7 required,which was not found in the registry

这是在注册表不能识别python2.7,原因windows是64位,安装的python是32位。怎么查看自己安装的python是多少位的呢?因为32位、64位都可以在64位操作系统中安装,所以年代久远的时候,就不记得当时自己安装的python是32呢,还是64了。查看非常之简单。输入平时我们检查是否有python环境的命令即可:

C:\Users\Administrator>python

MySQLdb for python(32/64位)下载地址:http://www.codegood.com/archives/129

解决方法:

1.新建一个register.py文件,将如下代码copy进去:

复制代码
#
# 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()
复制代码

2.定位到该文件所在目录运行python register.py

说明python2.7已经注册成功。

3.再执行MySQLdb安装程序,则会自动识别,并安装成功了。

注意:目前Mysqldb这个模块 不支持python3环境,所以我们的安装教程是以python2为主。

 

转载于:https://www.cnblogs.com/fighter007/p/9418130.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python可以通过MySQLdb模块来操作MySQL数据库。 首先需要安装MySQLdb模块,可以通过以下命令进行安装: ``` pip install MySQL-python ``` 连接数据库: ``` import MySQLdb # 打开数据库连接 db = MySQLdb.connect(host="localhost", user="root", passwd="password", db="test") # 使用cursor()方法获取操作游标 cursor = db.cursor() # 关闭数据库连接 db.close() ``` 创建表: ``` import MySQLdb db = MySQLdb.connect(host="localhost", user="root", passwd="password", db="test") cursor = db.cursor() # 使用execute()方法执行SQL语句 cursor.execute("CREATE TABLE employee (id INT, name VARCHAR(20), age INT, sex CHAR(1))") # 关闭数据库连接 db.close() ``` 插入数据: ``` import MySQLdb db = MySQLdb.connect(host="localhost", user="root", passwd="password", db="test") cursor = db.cursor() # SQL 插入语句 sql = "INSERT INTO employee(id, name, age, sex) VALUES (%s, %s, %s, %s)" # 执行SQL语句 cursor.execute(sql, (1, '张三', 20, 'M')) # 提交修改 db.commit() # 关闭数据库连接 db.close() ``` 查询数据: ``` import MySQLdb db = MySQLdb.connect(host="localhost", user="root", passwd="password", db="test") cursor = db.cursor() # SQL 查询语句 sql = "SELECT * FROM employee WHERE age > %s" # 执行SQL语句 cursor.execute(sql, (18,)) # 获取所有记录列表 results = cursor.fetchall() for row in results: id = row[0] name = row[1] age = row[2] sex = row[3] # 打印结果 print("id=%s,name=%s,age=%s,sex=%s" % (id, name, age, sex)) # 关闭数据库连接 db.close() ``` 更新数据: ``` import MySQLdb db = MySQLdb.connect(host="localhost", user="root", passwd="password", db="test") cursor = db.cursor() # SQL 更新语句 sql = "UPDATE employee SET age = age + 1 WHERE sex = %s" # 执行SQL语句 cursor.execute(sql, ('M',)) # 提交修改 db.commit() # 关闭数据库连接 db.close() ``` 删除数据: ``` import MySQLdb db = MySQLdb.connect(host="localhost", user="root", passwd="password", db="test") cursor = db.cursor() # SQL 删除语句 sql = "DELETE FROM employee WHERE age > %s" # 执行SQL语句 cursor.execute(sql, (30,)) # 提交修改 db.commit() # 关闭数据库连接 db.close() ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值