1

我是烧瓶的新手。我想以用于获取交付信息的形式显示类型(类型模型)的下拉列表。我创建了以下两个模型和烧瓶中的视图。我仍然没有得到下拉列表。如何使用以下模型在下拉列表中显示这些值。

class Types(Model):

    _tablename_ = 'types'
    id = Column(Integer, primary_key=True)
    type = Column(String(100),nullable=False)
    types = relationship('Delivery', backref='deliver_type', lazy= 'dynamic')

    def __repr__(self):
        return self.name

class Delivery(Model):

    _tablename_ = 'delivery'
    id = Column(Integer, primary_key=True)
    name = Column(String(250), nullable=False)
    type_id = Column(Integer, ForeignKey('types.id'))

观点是,

class DeliveryModelView(SupersetModelView, DeleteMixin):
    datamodel = SQLAInterface(models.Delivery)
    list_columns = ['name','type']
    search_columns = ['name','type']
    edit_columns = ['name','type']
    add_columns = edit_columns
    label_columns = {
        'name': _("Name"),
        'type': _("Type"),

    }

我需要在视图中添加什么,或者如果您能给我一些示例或教程,我将不胜感激。(使用 Jinja 模板)

4

1 回答 1

3

我设法通过仅更改模型来解决此问题。无需更改视图。我更改了模型如下。添加 type_id = Column(Integer, ForeignKey('types.id'), nullable=False), type = relationship('Types')到交付方法并删除类型模型中的关系。欲了解更多信息

class Types(Model):

    _tablename_ = 'types'
    id = Column(Integer, primary_key=True)
    name = Column(String(100),nullable=False)

    def __repr__(self):
        return self.name

class Delivery(Model):

    _tablename_ = 'delivery'
    id = Column(Integer, primary_key=True)
    name = Column(String(250), nullable=False)
    type_id = Column(Integer, ForeignKey('types.id'), nullable=False)
    type = relationship('Types')
于 2017-09-11T07:00:42.573 回答