我花了几个小时在这上面,没有运气看起来像一个bug。 所有字段都显示在我的查询结果中,但是“类型”并且“类型”和“发行者”之间没有区别,例如,两者都是foriegn键。石墨烯在它存在的时候随机移除它,当我在解析器中打印时,我看到它有一个值。当我尝试在graphiql中查询字段类型时,我收到以下错误:“无法在类型\”Post \“上查询字段\”type \“。” 有什么想法吗?
class T(models.Model):
type=models.CharField(default="type 1",null=False,blank=False,max_length=40)
def str(self):
return self.type
class Post(models.Model):
slug=models.SlugField(unique=True)
issuer=models.ForeignKey(User,on_delete=models.SET_NULL,blank=False,null=True,related_name="posts")
date_created=models.DateTimeField(default=timezone.now)
last_edited=models.DateTimeField(null=True)
num_interests = models.IntegerField(verbose_name="Number of interests so far",default=0)
status=models.CharField(max_length=30,default="posted")
tags=TaggableManager()
title=models.CharField (max_length=200,blank=False)
description =models.TextField(max_length=settings.MAX_TEXTAREA_LEN,default="",
validators=[MaxLengthValidatorFactory(settings.MAX_TEXTAREA_LEN)],blank=False)
goodUntil = models.DateField(verbose_name=_("Date"),default=datetime.now()+timedelta(days=7))
subjects=models.ManyToManyField(to=Subject,related_name='posts',blank=False)
type=models.ForeignKey(T,on_delete=models.SET_NULL,blank=False,null=True,related_name="type")
答案 0 :(得分:0)
如果我没记错的话,这是石墨烯中的一个错误 - 石墨烯在内部使用type
会干扰具有该名称的模型字段。我相信我可能在过去遇到过这个问题,并通过重命名我的模型字段来解决它。
在您的情况下,例如,重命名type
- > post_type
。
石墨烯具有这种限制是可以理解的,因为__type
在graphQL中具有特定含义。例如,这是一个名为“MyType”的DjangoObjectType
的有效查询:
{ __type(name:"MyType") {
fields {
name
description
}
}
}