PyMySQL模块安装
在使用 PyMySQL 之前,我们要先确保 PyMySQL 已安装。
pip install PyMySQL
数据库连接
使用pymysql连接数据库分为6步:
- 打开数据库连接
- 使用 cursor() 方法创建一个游标对象 cursor
- 使用 execute() 方法执行 SQL语句
- 使用 fetchone() 或者fetchall()方法获取单条或者全部数据
- 关闭游标
- 关闭数据库连接
import pymysql
# 1.连接数据库
db = pymysql.connect(
host="x.x.x.x", # 数据库所在机器IP
user="xxx", # 数据库连接用户名
passwd="xxx", # 连接数据库的密码
db="xxx", # 连接的数据库名
port=3306, # 端口
charset="utf8", # 编码格式
autocommit=True # 是否自动提交,操作数据必须为True,查询语句可不加改选项
)
# 2.使用 cursor() 方法创建一个游标对象 cur
cur = db.cursor()
# 3.使用 execute() 方法执行 SQL语句
cur.execute("SELECT * from user")
# 4.获取SQL返回数据
data = cur.fetchone()
data1 = cur.fetchall()
print(data)
print(data1)
# 5.关闭游标
cur.close()
# 6.关闭数据库连接
db.close()
输出:
(1, 'bai', '123456')
((2, 'hahaa', '123456'), (3, 'hahaa2', '12345600'))
执行查询SQL返回的数据为元组类型。
上面演示的表中共有3条数据,执行一次SQL,fetchone()返回第一条,fetchall()返回剩下的两条。如果将两个语句调换顺序,fetchall()会返回全部数据,fetchone()则返回空。
SQL语句可以传入变量去执行,写法和Python的格式化字符串相同。
sql = "select * from user where name = '%s'" % uname
cursor.execute(sql)
数据库的其他增删改操作更换对应的SQL语句即可。