Tengo una API GraphQL que se supone que devuelve datos de la base de datos MySQL y PostGres. En los resolutores, tengo console.log los resultados y puedo ver los datos en la terminal.
address: { type: AddressType, description: "An Address", args: { id: { type: GraphQLInt }, }, resolve: (parent, args) => { // Make a connection to MySQL let result; connection.query( `SELECT * FROM addresses WHERE id = ${args.id}`, (err, res, fields) => { if (err) console.log(err); console.log("========"); console.log(res); console.log("+++++++++"); console.log(res[0]); // console.log(result); } ); return result; }, },
En la terminal, puedo ver los resultados cuando ejecuto la consulta en GraphiQL:
[nodemon] starting `node schema.js` Server is running Connected to PSQL database. Connected to mySQL database. ======== [ RowDataPacket { id: 1, address_type: 'House', status: 'Inactive', entity: 'Building', number_and_street: 'PO BOX 276', suite_and_apartment: 'PO', city: 'Ennis', postal_code: '59729-0276', country: 'USA', notes: 'Dolorem quia repellendus et et nobis.', created_at: 2020-12-18T05:00:00.000Z, updated_at: 2021-05-21T04:00:00.000Z, latitude: null, longitude: null } ] +++++++++ RowDataPacket { id: 1, address_type: 'House', status: 'Inactive', entity: 'Building', number_and_street: 'PO BOX 276', suite_and_apartment: 'PO', city: 'Ennis', postal_code: '59729-0276', country: 'USA', notes: 'Dolorem quia repellendus et et nobis.', created_at: 2020-12-18T05:00:00.000Z, updated_at: 2021-05-21T04:00:00.000Z, latitude: null, longitude: null }
Sin embargo, en GraphiQL, obtengo un valor nulo para los datos. Aporte:
{ address(id: 1) { address_type } }
producción:
{ "data": { "address": null } }
Soy muy nuevo en GraphQL. ¿Qué me podría estar perdiendo aquí? Estoy intentando obtener esta información de la terminal para mostrarla al realizar una consulta en GraphiQL. Solo trato de aprender más.
El clásico problema con la falta de atención: usas la variable res
para la consola. Y en ninguna parte estás asignando un valor a result
.
Y el return result
se ejecuta antes de que se ejecute la consulta. (fuera de contexto donde tienes datos)
Consulte la documentación sobre cómo usar la sintaxis async / await
. Actualmente está utilizando devoluciones de llamada, que no es una sintaxis recomendada.
No estoy seguro, pero debería ser algo como, debe usar async/await
y esperar el retorno de los datos de la query
. También asegúrese de asignar el valor a la variable que tiene:
address: { type: AddressType, description: "An Address", args: { id: { type: GraphQLInt }, }, resolve: async (parent, args) => { const result = await connection.query('SELECT * FROM addresses WHERE id = $1', [args.id]); return result; }, },
Lo que terminó funcionando para mí fue lo siguiente:
address: { type: AddressType, description: "An Address", args: { id: { type: GraphQLInt }, }, resolve: async (parent, args) => { const [rows, fields] = await promisePool.query( `SELECT * FROM addresses WHERE id = ${args.id}` ); console.log(rows[0]); return rows[0]; }, },