Can Django';s ORM是否返回嵌套对象查询集?

Can Django';s ORM是否返回嵌套对象查询集?,django,django-models,django-orm,Django,Django Models,Django Orm,如果我有两个多对多关系模型,如下所示: class Topping(models.Model): name = models.CharField(max_length=50) class Pizza(models.Model): name = models.CharField(max_length=50) toppings = models.ManyToManyField(Topping) 我可以创建一个查询集来提供类似的信息吗 [ { "name": "

如果我有两个多对多关系模型,如下所示:

class Topping(models.Model):
    name = models.CharField(max_length=50)

class Pizza(models.Model):
    name = models.CharField(max_length=50)
    toppings = models.ManyToManyField(Topping)
我可以创建一个查询集来提供类似的信息吗

[
  {
    "name": "Hawaiian",
    "toppings": [
      {"name": "Pineapple"},
      {"name": "Canadian Bacon"},
      {"name": "Cheese"}
    ]
  },
  {
    "name": "Pepperoni Pizza",
    "toppings": [
      {"name": "Pepperoni"},
      {"name": "Cheese"}
    ]
  }
]

我可以在一行中创建嵌套对象查询集吗?

Django目前不支持直接从查询返回此类对象的查询方法,但是,您可以使用与
预回迁相关的
来获取
比萨饼
对象的
浇头
,然后用python构建嵌套对象:

pizzas = Pizza.objects.prefetch_related('toppings')

nested_obj = [{"name": pizza.name, "toppings": [{"name": topping.name} for topping in pizza.toppings.all()]} for pizza in pizzas]

您仍然可以使用一个查询。

谢谢摩西,这就是我要找的!现在是2019年,这仍然是真的吗?