Python Flask SQLalchemy 外键未保存在数据库中 - 一对多

标签 python python-2.7 flask sqlalchemy foreign-key-relationship

所以我有一个用户可以提交房间的表单,当然一个用户应该能够提交多个房间,但是这些房间都属于这个用户,所以我们这里有一个一对多的关系(为了理解):

room1 - 外键(用户1) room2 - 外键(用户1)

问题:

提交表单时,数据库识别到有外键函数,但users_id为空,但应该是提交房间的用户的实际id。

enter image description here

代码:

我尝试只显示相关的部分

这是我的模型:

class User(UserMixin, Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)

    # foreign key
    addresses = relationship('Zimmer', back_populates="users")

class Zimmer(Base):
    __tablename__ = 'zimmer'
    id = Column(Integer, primary_key=True)

    # foreign key
    users_id = Column(Integer, ForeignKey('users.id'))
    users = relationship("User", back_populates="addresses")

这是填充数据库的代码:

@app.route("/zimmer_einstellen", methods=['GET', 'POST'])
@login_required
@check_confirmed
def zimmer_einstellen():
    form = ZimmerForm()
    if form.validate_on_submit():
        new_zimmer = Zimmer(art=form.art.data, personen=form.personen.data,              preis=form.preis.data, infofeld=form.infofeld.data, land=form.land.data, bundesland=form.bundesland.data,
                    stadt=form.stadt.data, strasse=form.strasse.data, hausnr=form.hausnr.data, haustiere_erlaubt=form.haustiere_erlaubt.data,
                    bettwaesche_wird_gestellt=form.bettwaesche_wird_gestellt.data, grill_vorhanden=form.grill_vorhanden.data, safe_vorhanden=form.safe_vorhanden.data, kuehlschrank_vorhanden=form.kuehlschrank_vorhanden.data, rauchen_erlaubt=form.rauchen_erlaubt.data, 
                    parkplatz_vorhanden=form.parkplatz_vorhanden.data, kochmoeglichkeit_vorhanden=form.kochmoeglichkeit_vorhanden.data, restaurant_im_haus_vorhanden=form.restaurant_im_haus_vorhanden.data, handtuecher_werden_gestellt=form.handtuecher_werden_gestellt.data, tv_vorhanden=form.tv_vorhanden.data, 
                    waschmoeglichkeit_vorhanden=form.waschmoeglichkeit_vorhanden.data, wlan_vorhanden=form.wlan_vorhanden.data)

    if new_zimmer:
        db_session.add(new_zimmer)
        db_session.commit()

        flash('Zimmer wurde erfolgreich eingestellt')
        return redirect(url_for('zimmer_einstellen'))
    else:
            flash('Etwas ist schief gelaufen mit dem Einstellen des Zimmers')
return render_template('zimmer_einstellen.html', form=form)

但据我了解,创建外键关系应该足够了,仅此而已。

或者我是否必须在 html 的实际表单中使用类似附加隐藏标签之类的东西,这通常是我使用的(没有所有其他输入):

<form id="regi" method="POST" action="{{ url_for('zimmer_einstellen', next=request.args.get('next')) }}">
{{ form.hidden_tag() }}
<div class="form-group">
   {{ form.art.label }} 
   {{ form.art(size=30, class = "form-control") }} 
</div>


 </div>
 <div class="col-lg-12 col-md-12">
 <button type="submit" class="btn btn-success"> Zimmer einstellen </button>
 </div>

最佳答案

如果我正确理解您的问题,您还没有创建具有正确 users_id 的 Zimmer 对象: 你需要做这样的事情:

new_zimmer = Zimmer(..., users_id=user_id)

由于您无权访问 users_id,因此您需要获取它。正如您提到的,一种选择是将其作为隐藏输入放入 html 中,并在 zimmer_einstellen 函数中获取它。

更新:从您的用户声明中,我猜您正在使用 Flask-Login 扩展,它在您的应用程序中提供了current_user。如果是这种情况,您可以在 View 中使用 current_user.id 来获取当前用户的 ID。

关于Python Flask SQLalchemy 外键未保存在数据库中 - 一对多,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37728047/

相关文章:

python - 如何对 Get 和 Set 使用一个命令参数?

python - 检查下一行中的值,以便将某些规则应用于 Python 中的当前行

python - 如何使用 Flask 使 POST 方法适用于同一页面上的两种不同形式?

python - 什么时候应该使用 Flask.config 与使用 flask.session?

python - CeleryBeat 进程消耗所有操作系统内存

python - 使用crontab执行程序

python - 使用 sklearn 中的 minmaxScalar 缩放 NumPy 数组中具有多个特征的特定特征

c++ - 无法从C++启动可执行文件

python - flask -wtf : Using a kwarg to set the initial value for a field

python - 如何在不加载整个文件的情况下从 XLS 文件中获取工作表名称?