Я строю сервер GraphQL на expressjs. Ниже приведен код:
const express = require('express');
const app = express();
const {ApolloServer} = require('apollo-server-express');
const server = new ApolloServer({schema});
server.applyMiddleware({app, path: '/graphql'});
app.listen(4000,()=>console.log(`server started on port $4000}`));
Вот моя схема:
const typeDefs = `
input CustomersInput {
EMAIL_ADDRESS: String
NAME: String
HOME_PHONE: String
SPA_FOLIO_ID: ID
ALL_CUSTOMER_ID: ID
}
type Customer {
ALL_CUSTOMER_ID: ID
NAME: String
ALL_CUSTOMER_TYPE: String
FIRST_NAME: String
}
type Query {
customers(input: CustomersInput): [Customer]!
}
schema {
query: Query
}
`;
const resolvers = {
Query: {
customers(parent, args, ctx, resolveInfo) {
return joinMonster.default(resolveInfo,ctx, async sql=>{
console.log(sql)
return knex.raw(sql);
});
},
},
}
const schema = makeExecutableSchema({
typeDefs,
resolvers,
});
joinMonsterAdapt(schema, {
Query: {
fields: {
customers: {
where: (customerTable,args) => {
return escape(`${customerTable}.UPPER_FIRST_NAME || ' ' || ${customerTable}.UPPER_LAST_NAME || ' ' || ${customerTable}.UPPER_FIRST_NAME like %L`, `%${args.input.NAME.toUpperCase()}%`);
},
},
}
},
Customer: {
sqlTable: 'ALL_CUSTOMER',
uniqueKey: 'ALL_CUSTOMER_ID',
},
});
module.exports = schema;
Когда я запускаю приложение, и от go до http://localhost:4000/graphql
и используем запрос:
{
customers(input:{NAME: "as"}){
FIRST_NAME
ALL_CUSTOMER_ID
}
}
Я получаю обратно:
{
"data": {
"customers": [
{
"FIRST_NAME": null,
"ALL_CUSTOMER_ID": "563",
},
]
}
}
Это происходит потому, что когда я смотрю на запрос sql, который генерирует joinmonster, он запрашивает только идентификатор клиента и ничего больше, как видно ниже:
SELECT
"customers"."ALL_CUSTOMER_ID" AS "ALL_CUSTOMER_ID"
FROM ALL_CUSTOMER "customers"
WHERE "customers".UPPER_FIRST_NAME || ' ' || "customers".UPPER_LAST_NAME || ' ' || "customers".UPPER_FIRST_NAME like '%AS%'
Когда я запускаю точно такой же код, но вместо этого использую express-graphql
,
const expressGraphQL = require('express-graphql');
app.use('/graphql', expressGraphQL({
schema,
graphiql: true
}))
Это запрос, который генерирует монстр соединения:
SELECT
"customers"."ALL_CUSTOMER_ID" AS "ALL_CUSTOMER_ID",
"customers"."FIRST_NAME" AS "FIRST_NAME"
FROM ALL_CUSTOMER "customers"
WHERE "customers".UPPER_FIRST_NAME || ' ' || "customers".UPPER_LAST_NAME || ' ' || "customers".UPPER_FIRST_NAME like '%AS%'
И все работает как положено. Я что-то упустил?