解决can't connect to MySQL server on 'localhost'(10061)问题

  今天,用Python连接MySQL数据库时出现can’t connect to MySQL server on ‘localhost’(10061)问题,如图(1)所示:

这里写图片描述
图(1) error:10061 无法连接数据库

  但是,右击桌面右下角【开始】—》mySQL —》输入对应的密码和用户名,查询数据库xingqu里demo表却可以执行,如图(2)所示:
这里写图片描述
图(2) mySQL控制台里,却可以连接数据库

  这说明c:\windows\system32\drivers\etc目录里,文件hosts里的localhost属性没有配置,添加如下代码即可:

127.0.0.1 localhost

这里写图片描述
图(3) 在host里配置localhost属性:127.0.0.1 localhost

  另外,如果你的网络为IPv6,还需要在../MySQL/MySQL Server 5.1 /my.ini里,[mysqld]字段下配置bind-address属性,如下:   

bind-address = 127.0.0.1

这里写图片描述
图(4)在my.ini的【mysqld】字段下,配置bind-address属性: bind-address = 127.0.0.1

  Python连接MySQL5.1的测试代码:
  //linkDB.py  

import MySQLdb


try:
    conn=MySQLdb.connect(host='localhost',user='root',passwd='123456',
                         db='xingqu',port=3306)
    cur=conn.cursor()
    cur.execute('select * from demo')

    datas = cur.fetchall()
    for data in datas:
        print data[:]
    cur.close()
    conn.close()
except MySQLdb.Error,e:
     print "Mysql Error %d: %s" % (e.args[0], e.args[1])

  效果如下:

这里写图片描述
图(4)用Python连接MySQL5.1数据库的效果

  请根据自己MySQL的名称、密码、字符集、表格名进行修改。如果你MySQL的字符集为gb2312,则chartset=’gb2312’,代码为:   

import MySQLdb


try:
    conn=MySQLdb.connect(host='localhost',user='root',passwd='123456',
                         db='xingqu',port=3306,charset='gb2312')
    cur=conn.cursor()
    cur.execute('select * from demo')

    datas = cur.fetchall()
    for data in datas:
        print data[:]
    cur.close()
    conn.close()
except MySQLdb.Error,e:
     print "Mysql Error %d: %s" % (e.args[0], e.args[1])

  有时候,需要关闭防火墙显示地指明本机地址:127.0.0.1,代码如下:   

import MySQLdb


try:
    conn=MySQLdb.connect(host='127.0.0.1',user='root',passwd='123456',
                         db='xingqu',port=3306,charset='gb2312')
    cur=conn.cursor()
    cur.execute('select * from demo')

    datas = cur.fetchall()
    for data in datas:
        print data[:]
    cur.close()
    conn.close()
except MySQLdb.Error,e:
     print "Mysql Error %d: %s" % (e.args[0], e.args[1])
"Can't connect to MySQL server on localhost 10061 unknown error"是一个常见的MySQL连接错误。这个错误通常表示无法通过指定的主机和端口连接到MySQL服务器。可能的原因包括以下几点: 1. MySQL服务器未运行:请确保MySQL服务器已经启动。你可以尝试重新启动MySQL服务来解决问题。 2. 主机名或端口号错误:请确保你使用的是正确的主机名和端口号。默认情况下,MySQL服务器使用localhost作为主机名,端口号为3306。如果你使用了不同的主机名或端口号,请确认其正确性。 3. 防火墙阻止连接:防火墙设置可能会阻止与MySQL服务器的连接。请检查你的防火墙设置,确保允许从你的应用程序连接到MySQL服务器。 4. MySQL配置错误:有时候,MySQL服务器的配置文件可能存在问题,导致无法连接。你可以检查MySQL配置文件(通常是my.cnf或my.ini),确保其中的主机名和端口号与你尝试连接的一致。 5. MySQL授权问题:如果你使用了用户名和密码进行连接,可能是由于授权问题导致连接失败。请确保你使用的用户名和密码是正确的,并且具有足够的权限来连接到MySQL服务器。 如果以上方法都没有解决问题,你可以尝试在命令行中使用telnet命令来测试与MySQL服务器的连接。例如,使用以下命令测试连接到localhost的3306端口: ``` telnet localhost 3306 ``` 如果连接成功,你将看到一条欢迎消息。如果连接失败或超时,则表示存在其他问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sanqima

一键三连,多多益善

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值