SQLAlchemy: tabla de relaciones con clave primaria compuesta
Tengo un conjunto de tablas que se parecen a:
<code>workflows = Table('workflows', Base.metadata, Column('id', Integer, primary_key=True), ) actions = Table('actions', Base.metadata, Column('name', String, primary_key=True), Column('workflow_id', Integer, ForeignKey(workflows.c.id), primary_key=True), ) action_dependencies = Table('action_dependencies', Base.metadata, Column('workflow_id', Integer, ForeignKey(workflows.c.id), primary_key=True), Column('parent_action', String, ForeignKey(actions.c.name), primary_key=True), Column('child_action', String, ForeignKey(actions.c.name), primary_key=True), ) </code>
Mis clases de ORM parecen:
<code>class Workflow(Base): __table__ = workflows actions = relationship("Action", order_by="Action.name", backref="workflow") class Action(Base): __table__ = actions children = relationship("Action", secondary=action_dependencies, primaryjoin=actions.c.name == action_dependencies.c.parent_action, secondaryjoin=actions.c.name == action_dependencies.c.child_action, backref="parents" ) </code>
Entonces, en mi sistema, cada acción se identifica de forma única mediante una combinación de un ID de flujo de trabajo y su nombre. Me gustaría que cada acción tuvieraparents
ychildren
Atributo que refiere a sus acciones padre e hijo. Cada acción puede tener múltiples padres e hijos.
El problema ocurre cuando tengo una función como:
<code>def set_parents(session, workflow_id, action_name, parents): action = session.query(db.Action).filter(db.Action.workflow_id == workflow.id).filter(db.Action.name == action_name).one() for parent_name in parents: parent = session.query(db.Action).filter(db.Action.workflow_id == workflow.id).filter(db.Action.name == parent_name).one() action.parents.append(parent) session.commit() </code>
Me sale un error como:
<code>IntegrityError: (IntegrityError) action_dependencies.workflow_id may not be NULL u'INSERT INTO action_dependencies (parent_action, child_action) VALUES (?, ?)' (u'directory_creator', u'packing') </code>
¿Cómo obtengo la relación para configurar el workflow_id correctamente?