当前位置:网站首页 > SQL数据库编程 > 正文

pymysql 连接数据库(pymysql连接数据库失败)



Python 连接数据库失败怎么解决

什么是 PyMySQL?

PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。

PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。

在使用 PyMySQL 之前,我们需要确保 PyMySQL 已安装。

PyMySQL 下载地址:https://github.com/PyMySQL/PyMySQL。

如果还未安装,我们可以使用以下命令安装最新版的 PyMySQL:

$ pip3 install PyMySQL

以下实例链接 Mysql 的 TESTDB 数据库:

#!/usr/bin/python3 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","testuser","test123","TESTDB" ) # 使用 cursor() 方法创建一个游标对象 cursor cursor = db.cursor() # 使用 execute()  方法执行 SQL 查询  cursor.execute("SELECT VERSION()") # 使用 fetchone() 方法获取单条数据. data = cursor.fetchone() print ("Database version : %s " % data) # 关闭数据库连接 db.close()

报错如下:

Traceback (most recent call last): File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/site-packages/pymysql/connections.py", line 582, in connect kwargs) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/socket.py", line 727, in create_connection raise err File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/socket.py", line 716, in create_connection sock.connect(sa) ConnectionRefusedError: [Errno 61] Connection refused   During handling of the above exception, another exception occurred:   Traceback (most recent call last): File "mysql_conn.py", line 6, in <module> db = pymysql.connect("localhost","root","zjh","ryan" ) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/site-packages/pymysql/__init__.py", line 94, in Connect return Connection(*args, kwargs) File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/site-packages/pymysql/connections.py", line 327, in __init__ self.connect() File "/Library/Frameworks/Python.framework/Versions/3.7/lib/python3.7/site-packages/pymysql/connections.py", line 629, in connect raise exc pymysql.err.OperationalError: (2003, "Can't connect to MySQL server on 'localhost' ([Errno 61] Connection refused)")

在确定安装了 PyMySQL 以及数据库账号密码等没有问题时,还是不能连接 MySQL,

最后只剩下两种可能:

1. 运行 mysqladmin variables | grep socket 来获取套接字所在的位置,并尝试设置如下连接:

pymysql.connect(db='base', user='root', passwd='pwd', unix_socket="/tmp/mysql.sock")

2. 运行 mysqladmin variables | grep port 并验证端口是3306.如果没有,您可以手动设置端口,如下所示:

pymysql.connect(db='base', user='root', passwd='pwd', host='localhost', port=XXXX)
到此这篇pymysql 连接数据库(pymysql连接数据库失败)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • pymysql由于目标计算机积极拒绝(pymysql由于目标计算机积极拒绝,无法连接)2025-06-18 08:36:07
  • plsql1106注册码(plsql12注册码)2025-06-18 08:36:07
  • sqlldr导入时跳过一列(sqlldr 跳过某列)2025-06-18 08:36:07
  • 安装pymysql包的命令(安装pymysql失败)2025-06-18 08:36:07
  • sql的文件保存在哪里(sql数据库里的文件保存在哪个文件夹里?)2025-06-18 08:36:07
  • 增删改查sql语句语法结构(简单的增删改查sql语句)2025-06-18 08:36:07
  • sql文件怎么导入数据库mysql软件(sql文件怎么导入sqlyog)2025-06-18 08:36:07
  • mysql主键用自增还是用uuid(mysql主键自增原理)2025-06-18 08:36:07
  • sql文件怎么导入数据库sql server(sql文件怎么导入数据库)2025-06-18 08:36:07
  • pymysql连接池实现(pymysql数据库连接池)2025-06-18 08:36:07
  • 全屏图片