zoukankan      html  css  js  c++  java
  • 数据库插入失败 和回滚

    from app.web import web
    from flask_login import login_required,current_user
    from flask import current_app
    from app.models.gift import Gift
    from models.base import db

    @web.route('/gifts/book/<isbn>')
    @login_required
    def save_to_gifts(isbn):
      if current_user.can_save_to_list(isbn):
        try:
          gift = Gift()
          gift.isbn=isbn
          #获取当前用户的id
          gift.uid=current_user.id
          current_user.beans += current_app.config["BEANS_UPLOAD_ONE_BOOK"]    #这里调用current_user 为啥不用传入add 神奇,估计是自带add 语句
          db.session.add(gift)
          db.session.commit()     #当执行到这步的时候,数据才会插入到数据库
        except Exception as e:
          #事务回滚
          db.session.rollback()  #当commit()  失败后要执行回滚,不然下一个操作也会失败

          raise e
      else:
        flash("这本书已添加至您的赠送清单或已存在你的心愿清单")

  • 相关阅读:
    Spinal Tap Case
    Sorted Union
    Search and Replace
    Boo who
    Missing letters
    DNA Pairing
    Pig Latin
    Where art thou
    Roman Numeral Converter
    Redis高级客户端Lettuce详解
  • 原文地址:https://www.cnblogs.com/kaibindirver/p/12970077.html
Copyright © 2011-2022 走看看