如果我有两个处于多对多关系的模型,如下所示:
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]
您仍然可以使用一个查询。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)