Graphql对于字段的理解

参考:https://blog.csdn.net/z69183787/article/details/86756410 

type Query {
    selectUsers(id: Int): [User]
}
type User {
    id: Int
    age: Int
    userName: String!
    dogs(dogId:Int): [Dog]
}

按照我自己的理解,selectUsers(id: Int): [User]和id:Int没有本质的区别。都是这样的格式:

Field(Arguments)-可省略 :Type(标量类型或自定义类型)

在写Graphql服务端时候,我们要写selectUsers这个字段对应的解析函数。但是我发现,我们却不会写对id这个字段对应的解析函数。有点疑惑,直到看到了下面的描述:

http://blog.mygraphql.com/wordpress/?p=102

每个graphql schema 中的field,都需要绑定相应的 graphql.schema.DataFetcher 以获取数据. 其它GraphQL的实现把这叫 resolvers*.

很多时候,你可以用默认的 graphql.schema.PropertyDataFetcher 去从 Java POJO 中自动提取数据到对应的 field. 如果你未为 field 指定 data fetcher 那么就默认使用它.
PropertyDataFetcher 从 Map 和 Java Beans 中获取数据. 所以,当Schema中的field名,与Map中的key值,或 Source Object 中的 java bean 字段名相同时,不需要为field指定 DataFetcher.

对于上面的例子,id这个字段对应的解析函数就是graphql.schema.PropertyDataFetcher,这个函数将会从java pojo中自动提取数据到field。

你可能感兴趣的:(graphql)