Flask-SQLAlchemy 用 db.session.commit() 失败之后,事务会自动回滚吗? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
miniyao
V2EX    Python

Flask-SQLAlchemy 用 db.session.commit() 失败之后,事务会自动回滚吗?

  •  
  •   miniyao 2019-07-16 12:17:17 +08:00 8547 次点击
    这是一个创建于 2334 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Flask-SQLAlchemy (版本 2.3.0+) 事务提交,如果 db.session.commit() 失败,会自动回滚吗?

    db.session.add(something) db.session.commit() 

    有必要改成这样吗:

    db.session.add(something) try: db.session.commit() except: db.session().rollback() 
    11 条回复    2019-07-17 09:12:27 +08:00
    liuguichao
        1
    liuguichao  
       2019-07-16 13:01:14 +08:00
    有必要
    wenning
        2
    wenning  
       2019-07-16 13:01:37 +08:00 via Android
    有必要
    lihongjie0209
        3
    lihongjie0209  
       2019-07-16 13:03:33 +08:00
    你不会滚数据库也会超时, 所以看你的需求
    neoblackcap
        4
    neoblackcap  
       2019-07-16 13:04:16 +08:00
    用 with 语法不好么?
    lolizeppelin
        5
    lolizeppelin  
       2019-07-16 13:04:45 +08:00
    请使用 with 语法处理
    xxwnc
        6
    xxwnc  
       2019-07-16 14:57:39 +08:00
    SQLAlchemy 回滚之后如何再发起重试,保证业务能够实现??
    coolair
        7
    coolair  
       2019-07-16 15:55:40 +08:00
    @lolizeppelin #5
    @neoblackcap #4
    说用 with 的人,知道 with 是干嘛用的吗?这里不是 session.begin(),真是张口就来啊。
    neoblackcap
        8
    neoblackcap  
       2019-07-16 16:09:02 +08:00
    @coolair 哦!
    我是建议用 with 来改写着部分代码,不要用 try-catch 模式。还是你觉得这样改写有什么问题?
    yanzixuan
        9
    yanzixuan  
       2019-07-16 16:49:32 +08:00
    不 rollback 你下次写的时候直接报错。
    Tmac15
        10
    Tmac15  
       2019-07-17 09:03:50 +08:00
    with +1
    ampedee
        11
    ampedee  
       2019-07-17 09:12:27 +08:00 via Android
    这两天刚好也在研究这个问题
    首先 session.commit()失败后,数据库层面的事务会自动回滚,整个事务内的操作都不会写到磁盘中(在这个请求内调用 session 执行的所有查询写入操作都在这个事务内)。
    但是 sqlalchemy 层面也维护了一套事务的逻辑,当前 session 开启的事务被回滚之后,如果你需要继续使用这个 session 发起新的事务(执行查询或其他操作),必须调用 session.rollback(这里我的理解是对这个 session 进行回滚)。如果你不再需要使用这个 session,可以直接 close()关闭 session.
    因为 flask-sqlalchemy 会在每个请求上下文内自动创建销毁 session,所以结论是如果你需要在当前请求内继续使用 session,必须执行 session.rollback();如果确定不再需要这个 session 执行任何数据库操作了,可以不用 rollback,让它在请求结束时自动销毁。
    当然,大部分情况下我们会加入 session.rollback 封装起来进行复用。
    没看源码,根据文档和动手测试得出的结论,不一定准确
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1364 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 16:58 PVG 00:58 LAX 08:58 JFK 11:58
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86