首页 > 解决方案 > GraphQL 解析器仅解析第一种类型

问题描述

所以我在做我的一个项目,我的能力似乎走到了尽头。

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

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

这仅返回我的数据库中的所有方式,但用户返回 null

架构.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]
    }

解析器.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)
  }

使用上述查询,我​​希望结果也包括用户及其数据。

非常感谢任何建议。

标签: graphqlapollo-server

解决方案


只有字段,而不是类型,可以有解析器。对象中的每个键都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)
}

推荐阅读