【发布时间】:2019-05-03 02:26:41
【问题描述】:
我对 Graphene 非常陌生,并对其进行了测试,看看我是否可以将它用于具有复杂查询的 Django 项目。为了测试它,我正在尝试使用以下模型创建一个电子商务
class Sku(models.Model):
name = models.CharField(max_length=100)
class Product(models.Model):
name = models.CharField(max_length=100)
class ProductSku(models.Model):
sku = models.ForeignKey(Sku, related_name='product_sku', on_delete=models.CASCADE)
product = models.ForeignKey(Product, related_name='product_sku', on_delete=models.CASCADE)
price = models.IntegerField()
正如您在此处看到的,使用 ProductSku 模型,Product 和 Sku 具有多对多关系
使用 Graphene 的文档,我创建了以下架构
class SkuNode(DjangoObjectType):
class Meta:
model = Sku
class ProductNode(DjangoObjectType):
class Meta:
model = Product
class ProductSkuNode(DjangoObjectType):
class Meta:
model = ProductSku
class Query(graphene.ObjectType):
all_products = graphene.List(ProductNode, name=graphene.String())
product = graphene.Field(ProductNode, id=graphene.Int())
def resolve_all_products(self, info, **args):
name = args.get('name')
if name is not None:
return Product.objects.filter(name__icontains=name)
return Product.objects.all()
def resolve_product(self, info, **args):
id = args.get('id')
if id is not None:
return Product.objects.filter(pk=id).first()
现在,我的前端应用可以通过查询
来获取给定 sku 的给定产品的价格query{
allProducts{
id,
name,
productSku{
price,
sku{
id,
name
}
}
}
}
但我想做的是一个询问 SkuNode 内价格的查询
query{
allProducts{
id,
name,
sku{
id,
name,
price
}
}
}
这可能吗?
【问题讨论】:
-
感觉SKU一开始就不应该是自己的模型。这只是产品的一个属性。
标签: python django graphene-python graphene-django