Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/19.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Django:订单集查询_Django_Foreign Keys_Sql Order By_Django Queryset - Fatal编程技术网

Django:订单集查询

Django:订单集查询,django,foreign-keys,sql-order-by,django-queryset,Django,Foreign Keys,Sql Order By,Django Queryset,我有以下三种型号 class Product(models.Model): name = models.CharField( blank=False, max_length=256 ) class TaskGroup(models.Model): name = models.CharField( blank=False, max_length=256 ) product = model

我有以下三种型号

class Product(models.Model):

    name = models.CharField(
        blank=False,
        max_length=256
    )


class TaskGroup(models.Model):
    name = models.CharField(
        blank=False,
        max_length=256
    )

    product = models.ForeignKey(
        Product,
        on_delete=models.CASCADE,
        null=False,
        blank=True
    )


class Task(models.Model):
    name = models.CharField(
        blank=False,
        max_length=256
    )

    task_group = models.ForeignKey(
        TaskGroup,
        on_delete=models.CASCADE,
        null=False,
        blank=True
    )
    
    execute_at = models.DateField(
        blank=True
        null=True,
    )
我想获取产品的任务组,并通过execute_at为每个任务组订购任务。 我可以通过以下方式获取产品的所有任务组和所有任务:

product = Product.objects.first()
task_groups = product.taskgroup_set.all()
任务组
包含所有组以及每个组的所有任务。 我还可以执行类似于
任务组[0].task\u set.all().order\u by('execute\u at')
的操作。 我不知道如何将这些查询放在一起,并通过在单个查询中执行来对每个组的任务进行排序。

您可以使用并指定预取对象的查询集(这也有利于提高效率,因为对数据库的查询量会减少):

从django.db.models导入预取
product=product.objects.filter(pk=some\u pk)。预取\u相关(
预取(
“任务组任务集任务集”,
queryset=Task.objects.order\u by('execute\u at')
)
).get()#根据您的实现更改`.filter(pk=some_pk)`