Python pymysql模块基础教程:连接、SQL执行与安全性
63 浏览量
更新于2024-08-31
收藏 66KB PDF 举报
Python的pymysql模块是用于连接MySQL数据库并执行SQL操作的一个流行库。它提供了一种便捷的方式来与MySQL服务器交互,特别适用于Python开发人员在处理数据库查询和管理时的需求。
安装pymysql
首先,要在Python项目中使用pymysql,你需要通过pip安装这个模块,命令如下:
```bash
pip install pymysql
```
基本连接与操作
在使用pymysql时,你需要建立一个连接到MySQL服务器的对象。例如,以下代码创建了一个连接,指定主机(localhost)、数据库(db1)、字符集(utf8mb4),用户名(root)以及游标类型(DictCursor,使结果以字典形式返回):
```python
import pymysql
conn = pymysql.connect(
host="localhost",
database="db1",
charset="utf8mb4",
user="root",
cursorclass=pymysql.cursors.DictCursor
)
```
连接成功后,你可以创建一个游标对象来执行SQL语句:
```python
cursor = conn.cursor()
sql = "show tables"
res = cursor.execute(sql) # 执行SQL并获取受影响的行数
print(res) # 输出结果,如2表示有2个表
rows = cursor.fetchall() # 获取所有查询结果
for row in rows:
print(row)
cursor.close() # 关闭游标
conn.close() # 关闭数据库连接
```
游标和结果读取
游标在pymysql中扮演着关键角色,它是数据查询的迭代器,允许逐条读取查询结果。通过`fetchone()`、`fetchmany()`或`fetchall()`方法可以实现这一点。
预防SQL注入
当编写SQL语句时,务必注意防止SQL注入攻击。pymysql提供了`execute()`方法来确保字符串参数的安全拼接,避免使用`%`或`format()`等方法,因为它们可能导致不安全的字符串插值:
```python
sql = "SELECT * FROM t1 WHERE id = %s" # 使用占位符防止注入
id_value = 1
cursor.execute(sql, (id_value,))
```
注意事项
- 不要在SQL语句中直接插入表名或数据库名,因为这可能会导致语法错误,pymysql会在内部处理这些名称的插入。
- 在完成数据库操作后,确保关闭游标和连接,以释放系统资源。
pymysql模块为Python开发者提供了一个强大的工具,用于执行各种SQL查询,包括连接、执行、结果获取和安全的SQL构造。了解并掌握如何正确使用游标和预防SQL注入是高效利用这个模块的关键。
2020-12-24 上传
2020-08-07 上传
2023-09-20 上传
2023-03-07 上传
2023-07-12 上传
2023-03-07 上传
2023-04-04 上传
2024-10-25 上传
weixin_38635684
- 粉丝: 7
- 资源: 954
最新资源
- Aspose资源包:转PDF无水印学习工具
- Go语言控制台输入输出操作教程
- 红外遥控报警器原理及应用详解下载
- 控制卷筒纸侧面位置的先进装置技术解析
- 易语言加解密例程源码详解与实践
- SpringMVC客户管理系统:Hibernate与Bootstrap集成实践
- 深入理解JavaScript Set与WeakSet的使用
- 深入解析接收存储及发送装置的广播技术方法
- zyString模块1.0源码公开-易语言编程利器
- Android记分板UI设计:SimpleScoreboard的简洁与高效
- 量子网格列设置存储组件:开源解决方案
- 全面技术源码合集:CcVita Php Check v1.1
- 中军创易语言抢购软件:付款功能解析
- Python手动实现图像滤波教程
- MATLAB源代码实现基于DFT的量子传输分析
- 开源程序Hukoch.exe:简化食谱管理与导入功能