python pymysql 事务
时间: 2024-05-24 21:09:35 浏览: 20
Python pymysql 是一个Python的MySQL数据库驱动程序,它可以让我们方便地使用Python操作MySQL数据库。而事务是指作为一个单独的、不可分割的工作单位执行的一系列操作,只有所有操作都执行成功,才能提交事务;如果任意一个操作失败,就必须回滚事务,撤销已经执行的所有操作。下面介绍一下Python pymysql 中的事务处理。
在 Python pymysql 中,可以使用 connection 对象的 begin() 方法开启一个事务,使用 commit() 方法提交事务,使用 rollback() 方法回滚事务。当开启事务后,在所有的操作中,只有最后执行 commit() 才会将所有的操作提交到数据库中。
例如,下面的代码演示了如何使用 Python pymysql 开启事务、插入数据、更新数据和提交事务:
```
import pymysql
# 连接数据库
conn = pymysql.connect(host='localhost', port=3306, user='root', password='password', db='test')
try:
# 开启事务
conn.begin()
# 插入数据
cursor = conn.cursor()
cursor.execute("INSERT INTO student (name, age) VALUES ('Tom', 18)")
# 更新数据
cursor.execute("UPDATE student SET age = 20 WHERE name = 'Tom'")
# 提交事务
conn.commit()
except Exception as e:
# 回滚事务
conn.rollback()
finally:
# 关闭连接
conn.close()
```
在上面的代码中,我们使用了 try...except...finally 来处理异常和关闭连接,使用 conn.begin() 开启事务,使用 conn.commit() 提交事务,使用 conn.rollback() 回滚事务。注意,如果在执行过程中出现了异常,就会跳转到 except 语句块,执行回滚操作,撤销已经执行的所有操作。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)