新手学习时,遇到一个问题,GG查了下,看得不是很明白,因此这里请教一下。
要实现的:用户列表有一个「禁言」操作,点击后更新该用户的禁言字段的布尔值。
「禁言」操作是通过视图函数实现的:
@app.route('/member/status-false/<int:user_id>')
@login_required
def status_false(user_id):
from models import Member
user = Member.query.filter_by(id=user_id).first()
user.status = '0' #禁用用户
db.session.add(user)
db.session.commit()
return redirect(url_for('member'))
运行后,点击「禁言」Flask报错:
sqlalchemy.exc.InvalidRequestError: Object '' is already attached to session '1' (this is '2')
报错的问题大致理解是会话绑定对象乱掉了,但是不知道怎么修改上面的代码使得目的可以实现。
昨夜も引き続きいくつかの情報を確認しましたが、解決策は次のとおりです:
db.session の操作が view 関数に含まれたら、関数内で from models import db
を実行します。それは正常です。
1. db.session.add(user) を削除して試してください
2. ファイルの先頭にインポートの導入部分を配置します
結論:
リーリー理由:
リーリー