Python炼金术继承

Python炼金术继承,python,flask-sqlalchemy,Python,Flask Sqlalchemy,我正在尝试进行插入查询,但遇到以下错误: sqlalchemy.orm.exc.FlushError:正在尝试刷新类型为的项 作为集合“Tag.item”的成员。预期 类的类型或多态子类的对象 这种。如果是的子类,请配置映射器“mapper | Item | items”以加载此 子类型多态,或将enable_typechecks=False设置为允许任何 要接受刷新的子类型 插入查询 project = Proyecto.query.filter_by(id_project=i

我正在尝试进行插入查询,但遇到以下错误:

sqlalchemy.orm.exc.FlushError:正在尝试刷新类型为的项 作为集合“Tag.item”的成员。预期 类的类型或多态子类的对象 这种。如果是的子类,请配置映射器“mapper | Item | items”以加载此 子类型多态,或将enable_typechecks=False设置为允许任何 要接受刷新的子类型

插入查询

        project = Proyecto.query.filter_by(id_project=id_project).first()
        creado_en = datetime.datetime.utcnow()
        nuevo_hub = Hub(name,location,comments,creado_en)
        #FAIL HERE, even if Hub extends of Item
        nuevo_tag = Tag(project,nuevo_hub,TYPE_HUB,creado_en)
        db.session.add(nuevo_tag)
        db.session.add(nuevo_hub)
        db.session.commit()
代码的其余部分

class Item(db.Model):
    __tablename__ = "items"
    id_item     = db.Column(db.Integer, autoincrement=True, primary_key=True)
    type        = db.Column(db.Integer)
    created_at  = db.Column(db.DateTime)
    updated_at  = db.Column(db.DateTime)
    __mapper_args__ = {
        'polymorphic_identity': 'items',
        'polymorphic_on':type,
        'with_polymorphic':'*'
    }

    def __init__(self,creado_en=None):
        self.created_at = creado_en
        self.updated_at = creado_en



class Hub(Item):
    __tablename__ = "hubs"
    __mapper_args__ = {
        'polymorphic_identity': 0,
        'with_polymorphic':'*'
    }
    id_hub = db.Column(db.Integer, db.ForeignKey('items.id_item'), primary_key=True)
    # id_hub = db.Column(db.Integer, autoincrement=True, primary_key=True)
    name = db.Column(db.String(50), nullable=False, index= True)
    location = db.Column(db.String(50))
    comments = db.Column(db.String(128))
    created_at = db.Column(db.DateTime)
    updated_at = db.Column(db.DateTime)
    # conexiones = db.Column(db.Integer)

    def __init__(self, nombre=None, location=None,comments=None, creado_en=None):
        self.name = nombre
        self.location = location
        self.comments = comments
        self.created_at = creado_en
        self.updated_at = creado_en



class Tag(db.Model):
    __tablename__ = "tags"
    id_tag      = db.Column(db.Integer, autoincrement=True, primary_key=True)
    id_project  = db.Column(db.Integer,db.ForeignKey("projects.id_project"))
    id_item     = db.Column(db.Integer,db.ForeignKey("items.id_item"))
    project     = db.relationship(Proyecto, backref=db.backref('list_tags', lazy='dynamic'))
    item        = db.relationship(Item, backref=db.backref('list_tags', lazy='dynamic'))
    type        = db.Column(db.Integer) #(0,hub);(1,cable);(2,pipe);(3,electrical_pipes)
    created_at  = db.Column(db.DateTime)
    updated_at  = db.Column(db.DateTime)

    def __init__(self,project,item,type,created_at):
        self.project = project
        self.item = item
        self.type = type
        self.created_at = created_at
        self.updated_at = created_at

你在做什么类型的继承?您的映射器参数中没有
polymorphic\u on
concrete
。@univerio我已更新代码以使用polymorphic\u onNow一切正常@李嘉图:如果你知道了,你能用解释和代码示例回答你自己的问题吗?嗨@Ricardo,我今天面临着同样的错误,你是怎么知道的。。?请用你自己的问题回答:)你在做什么类型的继承?您的映射器参数中没有
polymorphic\u on
concrete
。@univerio我已更新代码以使用polymorphic\u onNow一切正常@李嘉图:如果你知道了,你能用解释和代码示例回答你自己的问题吗?嗨@Ricardo,我今天面临着同样的错误,你是怎么知道的。。?请用你自己的问题回答:)