内容简介:默认情况,MySQL执行的SQL是autocommit的,SALAlchemy 查询语句也是 autocommit的,就是说如果没有明确声明事务的begin,每个单独的SQL都是一个独立的事务。但是在做交易系统时,比如银行给用户A转账给用户B时,有两个操作,从A里面减100,然后给B加100。这两个操作必须放在一个事务里面才行,否是就会出现钱扣了,对方又没到账的情况。通过connection.begin 方法可以获取事务对象,执行完sql后,要把事务commit提交,如果出现异常,则把事务rollback,
默认情况,MySQL执行的 SQL 是autocommit的,SALAlchemy 查询语句也是 autocommit的,就是说如果没有明确声明事务的begin,每个单独的SQL都是一个独立的事务。但是在做交易系统时,比如银行给用户A转账给用户B时,有两个操作,从A里面减100,然后给B加100。这两个操作必须放在一个事务里面才行,否是就会出现钱扣了,对方又没到账的情况。
通过connection.begin 方法可以获取事务对象,执行完sql后,要把事务commit提交,如果出现异常,则把事务rollback,保证数据的最终一致性。
手动开始事务的几种方式:
connection = engine.connect(close_with_result=True)
trans = connection.begin()
try:
r1 = connection.execute("update account set blance-=100 where id=1")
r1 = connection.execute("update account set blance+=100 where id=2")
trans.commit()
except:
trans.rollback()
raise
当然,事务还有更优雅的写法,使用上下文管理器的特性,用 with 语句实现
with engine.begin() as connection:
r1 = connection.execute("update account set blance-=100 where id=1")
r1 = connection.execute("update account set blance+=100 where id=2")
少了好多行代码,执行完sql会自动提交,如果报异常会自动rollback 。
参考链接:
- https://docs.sqlalchemy.org/en/14/core/connections.html
以上所述就是小编给大家介绍的《SQLAlchemy Connection 事务操作》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Go 语言操作 MySQL 之 事务操作
- Java事务解析(事务的基本操作+隔离的等级+事务的四大特性+事务的概念)
- Redis事务操作
- MySQL常用高级操作:视图、事务、账户管理
- MySQL数据库简单操作及事务和索引
- golang 操作mysql示例(增、删、改、查、事务)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C程序设计题解与上机指导
谭浩强 / 清华大学 / 2000-9-1 / 19.50元
《C程序设计题解与上机指导(第2版)》是和谭浩强编著的《C程序设计》(第二版)(清华大学出版社1999年出版)配合使用的参考书,内容包括:(1)《程序设计》(第二版)一书的习题和参考解答,包括了该书各章的全部习题,共约150题,对全部编程题都给出了参考解答;(2)上机指南,详细介绍了在当前广泛使用的Turbo C集成环境下编辑、编译、调试和运行程序的方法,并简要介绍了Borland C++的使用方......一起来看看 《C程序设计题解与上机指导》 这本书的介绍吧!
HTML 压缩/解压工具
在线压缩/解压 HTML 代码
正则表达式在线测试
正则表达式在线测试