Joes svar (tilføj {"name":"ratio" , value:data.active/data.total}
til resultatet, når først resultatet er hentet fra databasen) ville gøre det uden at foretage skemaændringer.
Som en alternativ metode eller som en mere elegant måde at gøre det på i GraphQL, kan feltnavnene angives i selve typen i stedet for at sende dem som argumenter. Og udregn ratio
ved at skrive en resolver.
Så GraphQL-skemaet ville være:
Item {
total: Int,
active: Int,
ratio: Float
}
type Query {
items: [Item]
}
Klienten angiver felterne:
{
items {
total
active
ratio
}
}
Og ratio
kan beregnes inde i resolveren.
Her er koden:
const express = require('express');
const graphqlHTTP = require('express-graphql');
const { graphql } = require('graphql');
const { makeExecutableSchema } = require('graphql-tools');
const getFieldNames = require('graphql-list-fields');
const typeDefs = `
type Item {
total: Int,
active: Int,
ratio: Float
}
type Query {
items: [Item]
}
`;
const resolvers = {
Query: {
items(obj, args, context, info) {
const fields = getFieldNames(info) // get the array of field names specified by the client
return context.db.getItems(fields)
}
},
Item: {
ratio: (obj) => obj.active / obj.total // resolver for finding ratio
}
};
const schema = makeExecutableSchema({ typeDefs, resolvers });
const db = {
getItems: (fields) => // table.select(fields)
[{total: 10, active: 5},{total: 5, active: 5},{total: 15, active: 5}] // dummy data
}
graphql(
schema,
`query{
items{
total,
active,
ratio
}
}`,
{}, // rootValue
{ db } // context
).then(data => console.log(JSON.stringify(data)))