我对 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()
正如您在此处看到的那样,产品和 Sku 使用模型 ProductSku 具有多对多关系
使用来自 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
}
}
}
那可能吗?