gpt4 book ai didi

django - Django 的 ORM 可以返回嵌套对象查询集吗?

转载 作者:行者123 更新时间:2023-12-04 13:44:33 25 4
gpt4 key购买 nike

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

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 目前不支持直接从查询返回此类对象的查询方法,但是,您可以使用 prefetch_related得到toppings对于 pizza对象,然后在 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]

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

关于django - Django 的 ORM 可以返回嵌套对象查询集吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37533627/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com