6

我在烧瓶中有一个视图,当来自 POST 请求的对象成功提交时,我想用它来显示成功。

在控制器中,我有

us = User(data_that_is_not_valid)
db_session.add(us)
db_session.commit()

截至目前,当无法提交对象时,db_commit() 会引发异常。有没有更友好的方式,只返回 true 或 false 来指定对象是否已添加到数据库而不抛出错误?

编辑:添加了异常的副本

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/local/lib/python2.7/dist-packages/SQLAlchemy-0.8.0-py2.7-linux-x86_64.egg/sqlalchemy/orm/scoping.py", line 149, in do
    return getattr(self.registry(), name)(*args, **kwargs)
  File "/usr/local/lib/python2.7/dist-packages/SQLAlchemy-0.8.0-py2.7-linux-x86_64.egg/sqlalchemy/orm/session.py", line 719, in commit
    self.transaction.commit()
  File "/usr/local/lib/python2.7/dist-packages/SQLAlchemy-0.8.0-py2.7-linux-x86_64.egg/sqlalchemy/orm/session.py", line 350, in commit
    self._assert_active(prepared_ok=True)
  File "/usr/local/lib/python2.7/dist-packages/SQLAlchemy-0.8.0-py2.7-linux-x86_64.egg/sqlalchemy/orm/session.py", line 192, in _assert_active
    % self._rollback_exception
sqlalchemy.exc.InvalidRequestError: This Session's transaction has been rolled back due to a previous exception during flush. To begin a new transaction with this Session, first issue Session.rollback(). Original exception was: (IntegrityError) column email is not unique u'INSERT INTO users (name, email, password) VALUES (?, ?, ?)' ('test', 'test@test.com', 'test')
4

1 回答 1

8

无论如何,您的数据都应该准备好。但是这种情况不是数据格式的情况
而且异常总是好的,你只需要捕获并使用它们

您应该将异常视为返回 False,还应记录失败的原因以供以后解决问题

failed=False
try:
   db_session.commit()
except Exception as e:
   #log your exception in the way you want -> log to file, log as error with default logging, send by email. It's upon you
   db_session.rollback()
   db_session.flush() # for resetting non-commited .add()
   failed=True
#some use of failed var, specific for your case if you need it

为了更好地理解异常:Exceptions python docs
至于您的特定异常看起来像自动提交是您的问题。或者没有提交之前的一些 SQL 操作: Sqlalchemy docs

于 2013-05-02T11:02:42.683 回答