Я использую wtform как для добавления, так и для редактирования объекта, и я использую поле queryselect для внешних ключей. Поле queryselect всегда принимает первое значение в строке. Насколько я понимаю, правильное значение фактически передается правильно, просто по какой-то причине оно не принимается.
Модель, например:
class State(db.Model):
__tablename__ = 'state'
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
country_id = db.Column(db.Integer, db.ForeignKey('country.id'))
name = db.Column(db.String(150))
factor = db.Column(db.Float)
time_created = db.Column(DateTime(timezone=True),
server_default=func.now())
time_updated = db.Column(DateTime(timezone=True), onupdate=func.now())
def __init__(self, country_id, name, factor):
self.country_id = country_id
self.name = name
self.factor = factor
def __repr__(self):
return '{} - {}'.format(self.country_id, self.name)
Модель Страна
class Country(db.Model):
__tablename__ = 'country'
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
name = db.Column(db.String(150))
shortcut = db.Column(db.String(3))
states = db.relationship('State', backref='country', lazy=True)
time_created = db.Column(DateTime(timezone=True),
server_default=func.now())
time_updated = db.Column(DateTime(timezone=True), onupdate=func.now())
def __init__(self, name, shortcut):
self.name = name
self.shortcut = shortcut
def __repr__(self):
return '{} - {} - {}'.format(self.id, self.name, self.shortcut)
Вид:
@admin_blueprint.route('/admin/state/edit/<int:state_id>',
methods=['GET', 'POST'])
@login_required
def edit_state(state_id):
"""Edit state"""
obj = State.query.filter_by(id=state_id).first_or_404()
form = StateForm(obj=obj)
if request.method == 'POST' and form.validate_on_submit:
obj.country_id = form.country_id.data.id
obj.name = form.name.data
obj.factor = form.factor.data
db.session.commit()
log_entry_edit(State, obj)
return redirect(url_for('admin.list_states'))
return render_template('admin/state_form.html', form=form,
title='Edit State')
Форма:
def countries():
return Country.query
class StateForm(FlaskForm):
name = StringField('State Name')
factor = FloatField('Factor')
country_id = QuerySelectField('Country', query_factory=countries)
submit = SubmitField('Save')
Шаблон:
<div>
{{ form.country_id.label }}
{{ form.country_id(class="form-control form-group") }}
<output style="color: red;" for="country_id" id="selected-country_id">
ACTUAL ID: {{ form.country_id.data }}
</output>
</div>
{% if form.country_id.errors %}
<ul class="errors">
{% for error in country_id.errors %}
<li>{{ error }}</li>
{% endfor %}
</ul>
{% endif %}
Как вы можете видеть на следующем рисунке, форма принимает первое значение, и она также перезапишет БД, если я не выберу снова значение, которое я хотел впервое место. Фактическое правильное значение прибывает в форму, хотя (идентификатор красного цвета):
снимок экрана вывода шаблона
Я только начал работать с колбой, wtforms и т. Д., И я честноне вижу, что я делаю не так. У кого-нибудь есть подсказка?