我正面临石墨烯和Django的奇怪问题。文档似乎缺乏解决方案,我无法弄清楚我做错了什么。
我有以下型号:
Class Sentence(models.Model):
ref = models.CharField(max_length=30, primary_key=True)
body = models.TextField(default=None)
Class Summary(models.Model):
sentence = models.ForeignKey(Sentence, on_delete=models.CASCADE)
text = models.TextField(default=None)
(每个句子可以有多个摘要)
以下架构:
Class SentenceType(DjangoObjectType):
class Meta:
model = models.Sentence
filter_fields = {"ref": ["exact"]}
interfaces = (graphene.Node, )
Class SummaryType(DjangoObjectType):
class Meta:
model = models.Summary
filter_field = {"text": ["icontains"]}
interfaces = (graphene.Node, )
Class Query(graphene.ObjectType):
all_sentences = DjangoFilterConnectionField(SentenceType)
sentence = graphene.Field(SentenceType, ref=graphene.string(), body=graphene.string())
all_summary = all_provvedimenti = DjangoFilterConnectionField(SummaryType)
summary = graphene.field(SummaryType, id=graphene.Int(), text=graphene.string())
def resolve_all_summaries(self, context, **kwargs):
return models.Summary.objects.all()
我的数据库中可能会出现一个或多个摘要,但没有相应的句子。
现在,当我查询
时{
allSummaries{
edges{
node{
text
sentence{
ref
}
}
}
}
}
如果摘要存在句子,则完全没问题。 但如果没有相应的句子,我会得到:
"errors": [
{
"message": "Sentence matching query does not exist.",
"locations": [
{
"line": 6,
"column": 9
}
]
}
],
...,
...,
"data":[
...,
{
"node": null
},
{
"node":{
"text": "blah blah blah sentence summary"
"sentence": {
"ref": "sentence_reference"
}
}
}
{
"node": null
},
...,
]
当然,我期望的输出是,每当摘要节点不存在相应的句子时,它仍会返回摘要的文本和“句子”:null或[]。
我在文档或谷歌中没有运气。似乎我是唯一一个遇到这个问题的人。我无法理解我是否在Django,石墨烯或它只是一个错误中犯了一些错误。
有什么建议吗?
答案 0 :(得分:0)
更改此行中的all_summary
变量
all_summary = all_provvedimenti = DjangoFilterConnectionField(SummaryType)
到allSummaries
然后在
中更改函数名称def resolve_all_summaries(self, context, **kwargs):
也resolve_allSummaries
然后您可以使用以下查询:
{
allSummaries{
edges{
node{
text
sentence{
ref
}
}
}
}
}
所有这三个标识符都指向同一事物,因此需要匹配