繁体   English   中英

pymysql无法连接到mysql

[英]pymysql cannot connect to mysql

我正在尝试使用pymsql连接到MySQL数据库,主机为“ 115.28.236.225”,并使用默认端口:3306。代码如下(db_connect.py):

import pymysql

def connDB():
    conn=pymysql.connect(host='115.28.236.225',user='root',passwd='xxx',db='yyy',charset='utf8', port=3306)
    cur=conn.cursor();
    return (conn,cur);

conn,cur=connDB()

我使用python db_connect.py来运行,但是,我收到了错误消息pymysql.err.OperationalError: (1045, u"Access denied for user 'root'@'58.196.159.221' (using password: YES)") ,我不知道主机“ 58.196.159.221”来自何处,与代码中的主机不对应。

(我尝试使用MySql Workbench连接到MySQL,并且可以正常工作,因此,我确定python代码一定有问题)。

我该如何解决? 提前致谢!

pymysql很棒,因为它纯粹是用python实现的-没有外部依赖关系。

我敢打赌,您没有为外部帐户的root帐户设置适当的权限。 为什么你看到的原因pymysql.err.OperationalError: (1045,u"Access denied for user 'root'@'58.196.159.221'是因为你可能只具有访问MySQL的'root'@'localhost'58.196.159.221是运行python程序的系统的IP地址-不相信我吗?运行ifconfig并检查您的IP地址。

修复:连接到mysql控制台并运行以下命令:

GRANT ALL ON root.* TO 'root'@'58.196.159.221' IDENTIFIED BY 'ENTER_PASSWORD_HERE' ;
FLUSH PRIVILEGES;

这将允许远程访问mysql。

如果您只想从本地主机访问mysql,请运行以下命令:

GRANT ALL ON root.* TO 'root'@'localhost' IDENTIFIED BY 'ENTER_PASSWORD_HERE' ;
FLUSH PRIVILEGES;

如果要授予来自任何IP地址的访问权限,请执行以下操作:

GRANT ALL ON root.* TO 'root'@'%' IDENTIFIED BY 'ENTER_PASSWORD_HERE' ;
FLUSH PRIVILEGES;

FLUSH PRIVILEGES从mysql数据库重新加载特权,在更改用户权限后,这是必需的。

试试这个:

#!/usr/bin/python
import MySQLdb

db = MySQLdb.connect(host="115.28.236.225", user="root", passwd="xxx", db="yyy")      

cur = db.cursor()

cur.execute("SELECT * FROM YOUR_TABLE_NAME")

for row in cur.fetchall():
    print row[0]

db.close()

58.196.159.221最有可能是正在运行脚本的客户端的地址。 它无权访问您的远程数据库; 您将必须在MySQL本身中进行配置。

暂无
暂无

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

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