GraphQL解析器只解析第一种类型

问题描述 投票:1回答:1

所以我在我的一个项目上工作,我似乎用我的能力达到了死胡同。

我正在开发一个GraphQL后端,它应该从MySQL数据库中获取一些数据。我已经让解析器工作,所以我可以获取所有用户等,但我无法获取嵌套类型。例如:

query {
  ways {
    id
    distance
    duration
    purpose
    User {
      id
      dob
    }
  }
}

这只返回数据库中的所有方法,但User返回null

schema.ts

export const typeDefs= gql`
    schema {
        query: Query
    }

    type Query {
        ways: [Way]
        users: [User]
        getUser(id: String!): User
        getWay(id: String!):Way
    }
    type Way{
        id:String
        distance:Float
        duration:Float
        stages:[Stage]
        purpose:String
        User:User
    }
    type User{
        id:String
        firstname:String
        lastname:String
        sex:String
        dob:String
        annualTicket:Boolean
        Ways:[Way]
    }

resolver.ts

export const resolvers = {
  Query: {
    ways: async(parent, args, context, info) => {
      console.log("ways")
      const answer=await getAllWays();
      return answer;
    },
    users: async(parent, args, context, info) => {
      console.log("users")
      const answer=await getAllUser();
      return answer;

    },
    getUser: async(parent, args, context, info) =>{
      console.log("getUser")
      const answer=await getUserPerID(args.id);
      return answer;
    },
    getWay:async(parent, args, context, info) =>{
      console.log("getWay")
      const answer=await getWayPerID(args.id);
      return answer;
    }
  },
  User:async(parent, args, context, info) =>{
    console.log("User: id="+args.id)
    ways: User => getWaysPerUserID(args.id)
  },
  Way:async(parent, args, context, info) => {
    console.log("Way: id="+parent.userID)
    user: Ways => getUserPerID(parent.userID)
  }

我希望结果也包括用户及其数据,使用上面提到的查询。

任何建议都非常感谢。

graphql apollo-server
1个回答
0
投票

只有字段而不是类型才能有解析器。 resolvers对象中的每个键都应映射到另一个对象,而不是函数。而不是

Way:async(parent, args, context, info) => {
  console.log("Way: id="+parent.userID)
  user: Ways => getUserPerID(parent.userID)
}

你需要写:

Way: {
  // We capitalize the field name User because that's what it is in your schema
  User: (parent) => getUserPerID(parent.userID)
}
© www.soinside.com 2019 - 2024. All rights reserved.