假设我有一个Task
对象,可以依赖于其他Tasks
。有没有办法合理地热切/加入所有给定的任务子任务?
class Task(DeclarativeBase):
__tablename__ = 'task'
task_id = Column(Integer, primary_key=True)
name = Column(String, unique=True)
def add_dependencies(self, *tasks):
for task in tasks:
TaskDependency(dependent=self, dependency=task)
return self
@property
def dependencies(self):
return [x.dependency for x in self.dependency_edges]
@dependencies.setter
def dependencies(self, what):
"Note: adds dependencies, doesn't remove them"
self.add_dependencies(*what)
@property
def dependents(self):
return [x.dependent for x in self.dependent_edges]
class TaskDependency(DeclarativeBase):
__tablename__ = 'task_dependency'
dependent_id = Column(Integer, ForeignKey(Task.task_id), primary_key=True)
dependency_id = Column(Integer, ForeignKey(Task.task_id), primary_key=True)
dependent = relationship(Task, primaryjoin=dependent_id == Task.task_id,
backref='dependent_edges')
dependency = relationship(Task, primaryjoin=dependency_id == Task.task_id,
backref='dependency_edges')
def example_task_maker():
make_cheese = Task(
name="MAKE_CHEESE",
dependencies=[
Task(name="MILK_COWS",
dependencies=[
Task(name="BUY_COWS")
]),
]
)
def load_task()
# How to eagerly load the whole task tree here?
DBSession.query(Task).filter(name="MAKE_CHEESE").all()
答案 0 :(得分:2)
阿。我实际上是一个邻接列表,其中有一些例子可以在这里找到,我错过了:
http://docs.sqlalchemy.org/en/latest/orm/relationships.html#adjacency-list-relationships
我相信这会做我追求的目标。