gpt4 book ai didi

python - WTForms-Alchemy QuerySelectField 无法使用模型实例填充 model_id 字段

转载 作者:行者123 更新时间:2023-12-04 17:52:11 26 4
gpt4 key购买 nike

我想要一个 WTForms-Alchemy 表单来填充 Cloaker 模型的 template_id 字段。但是,我在调用 populate_obj 时收到 SQLAlchemy 无法调整 Template 的错误。我认为我的关系建立正确。为什么表单没有正确设置所选模板?

class Template(db.Model):
id = db.Column(db.Integer, primary_key=True)
cloaker = relationship('Cloaker', backref='cloaker')

class Cloaker(db.Model):
id = db.Column(db.Integer, primary_key=True)
template_id = db.Column(db.Integer, db.ForeignKey('template.id'), nullable=False)

class CloakerForm(ModelForm):
class Meta:
model = Cloaker

template_id = QuerySelectField(
query_factory=lambda: Template.query.all(),
get_pk=lambda a: a.id,
get_label=lambda a: a.name,
allow_blank=True,
blank_text=u'-- please choose --'
)

form.populate_obj(cloaker) 给出以下错误:

ProgrammingError: (psycopg2.ProgrammingError) can't adapt type 'Template' [SQL: 'INSERT INTO cloaker (status, created_at, updated_at, domain, safepage_url, moneypage_url, template_id, "user", company, country, connection_id, lp) VALUES (%(status)s, %(created_at)s, %(updated_at)s, %(domain)s, %(safepage_url)s, %(moneypage_url)s, %(template_id)s, %(user)s, %(company)s, %(country)s, %(connection_id)s, %(lp)s) RETURNING cloaker.id'] [parameters: {'status': None, 'domain': u'1', 'moneypage_url': u'asdv', 'template_id': <automata.cloaker.models.Template object at 0x10fd87990>, 'country': u'', 'created_at': datetime.datetime(2017, 5, 4, 23, 12, 3, 380155), 'connection_id': u'', 'updated_at': datetime.datetime(2017, 5, 4, 23, 12, 3, 380167), 'safepage_url': u'sdv', 'user': u'asdva', 'lp': u'', 'company': u''}]

最佳答案

您正在尝试填充外键字段 template_id,而不是关系。

QuerySelectField 通过 id 而不是 id 选择一个实例。将您的字段命名为 template。修复你的关系 backref 被称为 template,因为 Cloaker.cloaker 没有多大意义。 populate_obj 会将 Cloaker.template 关系设置为选定的 Template,SQLAlchemy 将正确处理它。

class Template(db.Model):
id = db.Column(db.Integer, primary_key=True)

class Cloaker(db.Model):
id = db.Column(db.Integer, primary_key=True)
template_id = db.Column(db.ForeignKey(Template.id), nullable=False)
template = db.relationship(Template)

class CloakerForm(ModelForm):
template = QuerySelectField(...)

关于python - WTForms-Alchemy QuerySelectField 无法使用模型实例填充 model_id 字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43786901/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com