背景:Flask / Flask-SQLAlchemy / Flask-WTF,使用声明性和作用域会话
操作简单POST
:
@tas.route('/order_add', methods=['GET', 'POST'])
def tas_order_add():
if request.method == 'POST':
order_form = OrderForm()
if order_form.validate_on_submit():
order = Order()
order_form.populate_obj(order)
db_session.add(order)
db_session.commit()
现在尝试运行它我得到一个错误:
InvalidRequestError:对象“”已附加到会话“1”(这是“2”)
将 add 更改为 merge 可以解决问题,但是:
- 我不知道为什么我刚启动它时必须合并一个对象
如果我确实更改添加以合并并尝试定义其中一个属性
order = Order() order_form.populate_obj(order) order.order_status = OrderStatus.query.filter(OrderStatus.code=='PLACED').first() db_session.merge(order) db_session.commit()
我得到了同样的错误,就在 OrderStatus 对象上
InvalidRequestError:对象“”已附加到会话“2”(这是“1”)
有人可以指出我做错了什么,因为它让我发疯。我确实有一些使用 SQLAlchemy 的经验,但这是我第一次看到这种行为,我无法查明问题所在。
搜索我发现的所有问题都是双数据库会话初始化的问题,但我不相信是这种情况。
编辑
db_session 在单独的文件 database.py 中定义,内容如下
from sqlalchemy.engine import create_engine
from sqlalchemy.ext.declarative.api import declarative_base
from sqlalchemy.orm.scoping import scoped_session
from sqlalchemy.orm.session import sessionmaker
engine = create_engine('sqlite:///fundmanager_devel.db', convert_unicode=True)
db_session = scoped_session(sessionmaker(autocommit=False,
autoflush=False,
bind=engine))
Base = declarative_base()
Base.query = db_session.query_property()