繁体   English   中英

如何返回没有 SQLAlchemy 类型的自定义子项 object

[英]How to return custom child object that does not have a SQLAlchemy type

我有FooBar类型的对象,每个Bar object 都有一个字段类别(由名称字符串指定)和一个将其链接到Foo类型的 object 的父 ID ...我希望有一个 GQL 模式,可以查询为如下:

{ 
   foo {
      category {
           name
           bar {
                
           }
      }
}

Foo 和 Bar 都存在于数据库中,可以很容易地生成为 SQLAlchemy 个对象。 但是我不太确定如何编写一个给定 Foo object 的解析器以这种方式返回它的所有类别,以及如何编写一个给定类别的解析器返回该类别中属于 foo 的子对象的所有对象.

所以你在这里需要的是一个自定义的CategoryType

class CategoryType(graphene.ObjectType):
    name = graphene.String()
    bars = graphene.List(BarType)

然后在你的FooType

class FooType(SQLAlchemyObjectType):
    class Meta:
        model = Foo

    categories = graphene.List(CategoryType)

    def resolve_categories(self, info):
        organized = {}
        for bar in self.bars:
            if (bar.category in organized):
                organized[bar.category].append(bar)
            else:
                organized[bar.category] = [bar]

        return [{ "name": name, "bars": bars } for name, bars in organized.items()] 


暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM