想不出更合适的问题标题,但我正在寻找一些关于如何实现以下要求的建议:
我有一个Project
类,它可能包含Task
对象。任务有一个受理人。在我的 Django 模板中,我想为给定用户呈现项目和任务的“树”,只显示那些至少有一个任务分配给用户的项目,并且在每个项目中,只显示那些分配给用户。
我最初的方法是首先找到至少有一个分配任务的项目:
def list_assigned_tasks(request, assignee_id):
projects = Project.objects.filter(task__assignee=assignee_id).distinct()
# ...
(不是最有效的方法,但我只处理少量的项目和任务。)
然后我想我可能会编写一个方法Project
来仅检索分配给用户的那些任务:
class Project(models.Model):
# ...
def assigned_tasks(self, assignee_id):
return self.task_set.filter(assignee=assignee_id)
或类似的东西。
但是,我不能直接从模板中调用该方法。所以,我的问题是:有没有更好的方法来实现这一目标?寻找有关 QuerySet 和模板实现的建议。
(我的另一个想法是将分配的任务固定到每个项目实例中list_assigned_tasks
- 这是一种有效的方法吗?)