import pymysql
sql = "select host,user,password from user" #想要執行的MySQL語句
#sql = 'create database sss character set utf8'
#打開數據庫連接
db = pymysql.connect(host="192.168.254.40", user="root",
password="root", db="mysql", port=3306)
cur = db.cursor()#使用cursor()方法獲取操作游標
cur.execute(sql) # 執行sql語句
results = cur.fetchall() # 獲取查詢的所有記錄
for i in results:#遍歷結果
print(i)
db.close() # 關閉連接
pymysql:Mysql拒絕從遠程訪問的解決辦法
報錯內容
Traceback (most recent call last):
File "E:/untitled1/lvs_rr.py", line 15, in <module>
password="1", db="mysql", port=3306)
File "E:\untitled1\lib\site-packages\pymysql\__init__.py", line 94, in Connect
return Connection(*args, **kwargs)
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 325, in __init__
return Connection(*args, **kwargs)
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 325, in __init__
self.connect()
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 599, in connect
self._request_authentication()
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 861, in _request_authentication
auth_packet = self._read_packet()
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 684, in _read_packet
packet.check_error()
File "E:\untitled1\lib\site-packages\pymysql\protocol.py", line 220, in check_error
err.raise_mysql_exception(self._data)
File "E:\untitled1\lib\site-packages\pymysql\err.py", line 109, in raise_mysql_exception
raise errorclass(errno, errval)
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 325, in __init__
self.connect()
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 599, in connect
self._request_authentication()
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 861, in _request_authentication
auth_packet = self._read_packet()
File "E:\untitled1\lib\site-packages\pymysql\connections.py", line 684, in _read_packet
packet.check_error()
File "E:\untitled1\lib\site-packages\pymysql\protocol.py", line 220, in check_error
err.raise_mysql_exception(self._data)
File "E:\untitled1\lib\site-packages\pymysql\err.py", line 109, in raise_mysql_exception
raise errorclass(errno, errval)
解決方法:
添加用戶允許從任何主機連接到mysql服務器
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;
即時生效
FLUSH PRIVILEGES;