当前位置:  开发笔记 > 编程语言 > 正文

pymysql无法连接到mysql

如何解决《pymysql无法连接到mysql》经验,为你挑选了1个好方法。

我试图使用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代码有问题).

我怎么解决这个问题?提前致谢!



1> OkezieE..:

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数据库重新加载权限,这在您更改用户权限后是必需的.

推荐阅读
k78283381
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有