Как получить заполненные значения модели в списке GraphqQL без ссылки _id?

У меня есть модель Users с некоторыми полями и ссылкой на модель "Skills".

Модели похожи на это ниже

1.Users.js (модель пользователя)

 const mongoose = require('mongoose');
 const Schema = mongoose.Schema;

 const UsersSchema = new Scheam({
     name: { type : String },
     email: { type : String },
     address: { type : String },

     Skills: [{ type: mongoose.Schema.Types.ObjectId, ref: 'Skills' }],
 })

 module.exports = mongoose.model('Users', UsersSchema);

2. Навыки Модель

const mongoose = require('mongoose')
const Schema = mongoose.Schema;

const SkillsSchema = new Schema({
   name : { type: String },
});

module.exports = mongoose.model('Skills', SkillsSchema);

Я создаю нового пользователя с выпадающим меню выбора навыков, в котором хранятся идентификаторы навыков в модели пользователей.

И получить навыки, заполнив модель Users таким образом, в приложении node js.

  export function getUser(req, res) {
     console.log('getUser');
     console.log('req.body',req.body);
     Users.findOne({_id: req.body.user_id}).populate('skills').exec(function(err, usr_doc){ 
       if(err) {
          res.json({
             status: 401,
             message: 'something went wrong!',
             err: err,
          });
       } else if (!err && usr_doc != null) {
           res.json({
               status: 200,
               message: 'User details found!',
               data: {_id: usr_doc._id, skills: usr_doc.skills,name: usr_doc.name,token: usr_doc.token},
           })
       }
     })//Users.findOne end
  }

Приведенный выше код работает нормально для нормального отдыха API.

Здесь я пытаюсь создать Same API, используя GraphQL сервер express-graphql в Nodejs.

Код выглядит так.

3.Schema.js

 const graphql = require('graphql');
 const Users = require('../models/Users');
 const Skills = require('../models/Skills');

 const { 
    GraphQLObjectType,
    GraphQLInt,
    GraphQLFloat,
    GraphQLString, 
    GraphQLSchema,
    GraphQLID,
    GraphQLList,
    GraphQLNonNull,
    GraphQLBoolean,
    GraphQLObject
 } = graphql;

 const UsersType = new GraphQLObjectType ({
       name: 'Users',
       fields: () => ({
            id: {type: GraphQLID},
            name: { type : GraphQLString },
            email: { type : GraphQLString },
            **skills: {
                type: new GraphQLList(SkillsType),
                resolve(parent, args){
                  //Here I need to know how to get the skills name of the users
                }
            }**
       })

   const SkillsType = new GraphQLObjectType({
       name: 'Skills',
       fields: () => ({
          name: { type : GraphQLString },
       })
   })    

В настоящее время я не использовал ссылочный идентификатор в модели навыков, только имя. Я хочу получить имена умений пользователей.

Если я использую нижеприведенное, я получаю все имена навыков вместо конкретных или заполненных имен навыков.

   skills : {
     type: new GraphQLList(SkillsType),
        resolve(parent, args){
            return Skills.find({})
        } 

Пожалуйста, предоставьте любые предложения по этому поводу.

Я могу дать больше информации, если вам нужно.

1 ответ

Решение

Чтобы получить skills пользователя, а не Skills.find({}) который возвращает все документы, присутствующие в коллекции навыков, добавьте условие с parent объект.

parent объект, который содержит результат от преобразователя на родительском поле здесь. Таким образом, навыки, определяющие ребенка, можно записать как:

 skills: {
     type: new GraphQLList(SkillsType),
     resolve(parent, args) {
         return await Skills.find({"_id": {$in: parent.skills} }) }
 } 
Другие вопросы по тегам