猫鼬关系一对多不起作用

时间:2015-03-12 10:16:34

标签: node.js mongodb express mongoose meanjs

我有一对多的mongoose架构关系问题:我有两个文档公司和代理,当我尝试保存公司文档时,它无法保存。注意:父文档是公司,子项是代理:

公司架构

'use strict';

/**
* Module dependencies.
*/
var mongoose = require('mongoose'),
Schema = mongoose.Schema;

/**
* Company Schema
*/
var CompanySchema = new Schema({
name: {
    type: String,
    default: '',
    //required: 'Please fill Company name',
    trim: true
},
created: {
    type: Date,
    default: Date.now
},
updated: {
    type: Date,
    default: Date.now
},
address: {
    type: String,
    default: '',
    //required: 'Please fill Company address',
    trim: true
},
locked: {
    type: Boolean,
    default: true,
},
deleted: {
    type: Boolean,
    default: false,
},
logo: {
    type: String,
    default: '',
},
email: {
    type: String,
    default: '',
    //required: 'Please fill Company email',
},
tel: {
    type: String,
    default: '',
    //required: 'Please fill Company tel',
},
fax: {
    type: String,
    default: '',
    //required: 'Please fill Company fax',
},
type: {
    type: String,
    //required: 'Please fill Company type',
    trim: true
},
description: {
    type: String,
    default: '',
    trim: true
},
user: {
       type: Schema.ObjectId,
       ref: 'User'
   },
   agents: [{
      type: Schema.ObjectId,
      ref: 'Agent'
   }]
});

mongoose.model('Company', CompanySchema);

代理架构

'use strict';

/**
* Module dependencies.
*/
 var mongoose = require('mongoose'),
Schema = mongoose.Schema;

/**
* Agent Schema
*/
var AgentSchema = new Schema({
// Agent model fields   
// ...
firstname: {
    type: String,
    default: ''
},
lastname: {
    type: String,
    default: ''
},
email: {
    type: String,
    default: ''
},
password: {
    type: String,
    default: ''
},
roles: {
    type: Array,
},
created: {
    type: Date,
    default: Date.now
},
updated: {
    type: Date,
    default: Date.now
},
deleted: {
    type: Boolean,
    default: false
},
locked: {
    type: Boolean,
    default: false
},
company: {
    type: Schema.ObjectId,
    ref: 'Company'
  }
});

var exports = module.exports = mongoose.model('Agent', AgentSchema);

API

company.save(function(err){
  if(err){
    console.log('company err');
    return res.status(400).send({
      messages: errorHandler.getErrorMessage(err)
    });
  }else{
    console.log('company save');
    var agents = preapareAgents(req, company);
    Agent.create(agents, function(err){
      if(err){
        return res.status(400).send({
          messages: errorHandler.getErrorMessage(err)
        });
      }else{
        res.jsonp({
          company: company,
          agents: agents
        });
      }
    });
  }
});

prepareAgent

var preapareAgents = function(req,company){
var admin = new Agent(req.body.admin);
admin.roles = ['admin', 'read','write'];
admin.company = company;
admin.locked = false;

var agents = req.body.agents;

for (var i = 0; i <= agents.length - 1; i++) {
    agents[i].roles = [agents[i].role];
    agents[i] = new Agent(agents[i]);
    agents[i].company = company;
}

agents.push(admin);

return agents;
};

****错误:
 CastError:对于路径“agents”

的值“[object Object]”,Cast to ObjectId失败

3 个答案:

答案 0 :(得分:0)

在prepareAgents方法中,每个代理的公司必须是公司的_id而不是Object公司。您的代码应如下所示:

for (var i = 0; i <= agents.length - 1; i++) {
    agents[i].roles = [agents[i].role];
    agents[i] = new Agent(agents[i]);
    agents[i].company = company._id; //here is the problem
}

尝试一下,也许我错了。

答案 1 :(得分:0)

这不是问题的根源,但是当我从公司模型中删除代理商集合时,这条线会导致问题:

   agents: [{
     type: Schema.ObjectId,
     ref: 'Agent'
   }]

答案 2 :(得分:-2)

我通过使用其他名称重命名代理程序集合来解决问题:)