繁体   English   中英

在 Centos 上安装 mysql-python

[英]Installing mysql-python on Centos

我正在尝试在 centos 5.5 上安装 MySQL-python 库。 我跑了

sudo yum install MySQL-python

但是当我尝试时:

import MySQLdb

我收到此错误:

Traceback (most recent call last):
  File "<stdin>", line 1, in ?
  File "MySQLdb/__init__.py", line 22, in ?
    raise ImportError("this is MySQLdb version %s, but _mysql is version %r" %
ImportError: this is MySQLdb version (1, 2, 3, 'final', 0), \ # added linebreak
but _mysql is version (1, 2, 1, 'final', 1)

关于如何解决这个问题的任何线索?

第 1 步- 安装软件包

# yum install MySQL-python
Loaded plugins: auto-update-debuginfo, langpacks, presto, refresh-packagekit
Setting up Install Process
Resolving Dependencies
--> Running transaction check
---> Package MySQL-python.i686 0:1.2.3-3.fc15 will be installed
--> Finished Dependency Resolution

Dependencies Resolved

================================================================================
 Package              Arch         Version                 Repository      Size
================================================================================
Installing:
 MySQL-python         i686         1.2.3-3.fc15            fedora          78 k

Transaction Summary
================================================================================
Install       1 Package(s)

Total download size: 78 k
Installed size: 220 k
Is this ok [y/N]: y
Downloading Packages:
Setting up and reading Presto delta metadata
Processing delta metadata
Package(s) data still to download: 78 k
MySQL-python-1.2.3-3.fc15.i686.rpm                       |  78 kB     00:00     
Running rpm_check_debug
Running Transaction Test
Transaction Test Succeeded
Running Transaction
  Installing : MySQL-python-1.2.3-3.fc15.i686                               1/1 

Installed:
  MySQL-python.i686 0:1.2.3-3.fc15                                              

Complete!

第 2 步- 测试工作

import MySQLdb
db = MySQLdb.connect("localhost","myusername","mypassword","mydb" )
cursor = db.cursor()
cursor.execute("SELECT VERSION()")
data = cursor.fetchone()    
print "Database version : %s " % data    
db.close()

输出:

Database version : 5.5.20 

我有Python 2.7.5、MySQL 5.6 和 CentOS 7.1.1503

对我来说,它使用以下命令:

# pip install mysql-python

请注意这里的先决条件:

安装 Python pip:

# rpm -iUvh http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm

# yum -y update
Reboot the machine (if kernel is also updated)

# yum -y install python-pip

安装 Python 开发包:

# yum install python-devel

安装 MySQL 开发包:

# yum install mysql-devel

对于centos7,我需要: sudo yum install mysql-devel gcc python-pip python-devel sudo pip install mysql-python

因此, gccmysql-devel (而不是mysql )很重要

您可能没有通过 yum 安装 MySQL? 存储库中 MySQLDB 的版本与存储库中的 MySQL 版本相关联。 版本需要匹配。

您的选择是:

  1. 安装 MySQL 的 RPM 版本。
  2. 将 MySQLDB 编译为您的 MySQL 版本。

mysql-python支持Python3 ,您可能需要:

sudo pip3 install mysqlclient

另外,请查看此帖子以获取更多替代方案。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM