如何在mongoose引用模式中使用$ in

时间:2015-07-09 05:56:26

标签: node.js mongodb mongodb-query

我有2个模式第1个是城市,第二个是密码。 Pincode参考了城市。它们看起来都像这样

CITY架构

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

// create a all city list
var allCitySchema = new Schema({
    cities: {
      type: String
    }
}, {collection: 'allcities'});

var allcities = mongoose.model('allcities', allCitySchema);
module.exports = allcities;

Pincode架构

var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var allPincode = new Schema({
    city_id: {
        type: Schema.ObjectId,
        ref: 'allcities'
    },
    pincode: {
        type: String
    }
}, {collection: 'pincode'});

var allPincode = mongoose.model('pincode', allPincode);
module.exports = allPincode;

现在的问题是,当我尝试根据城市ID获取所有密码时,我尝试这样尝试

 app.post('/api/getPincodeByCity', function(req, res) {
        console.log("In pincode");
        var cities_id = [];
        cities_id = req.body.cities_id;
        console.log(req.body); // { cities_id: '["5597aa08c0a0beb40be128d4","5597aa2bbb18fefc142b6915"]' }
        console.log(cities_id);
        pincodes.findById( {city_id: { $in: cities_id }}, function(err,pincodeIds){
            if(err) res.send(err.message);
             res.send(pincodeIds);
             res.end('{"success" : "Recieved Successfully", "status" : 200}');
        });
    });

但它没有给我这个错误

Cast to ObjectId failed for value "[object Object]" at path "_id"

我也尝试使用find()代替findById()方法,但它给了我这个错误

undefined is not a function

1 个答案:

答案 0 :(得分:1)

$in运算符不仅仅是“严格”用于查询数组,因为基本上任何运算符都可以用于奇异值。

它实际上是一个“参数列表”,其评估为$or条件,but with shorter syntax

   var idList = ["559e0dbd045ac712fa1f19fa","559e0dbe045ac712fa1f19fb"];

   var pincode = mongoose.model('pincode');

   pincode.find({ "city_id": { "$in": idList } },function(err,docs) {
      // do something here
   });

如上所述,这是简短形式:

  pincode.find(
      {
          "$or": [
              { "city_id": "559e0dbd045ac712fa1f19fa" },
              { "city_id": "559e0dbe045ac712fa1f19fb" }
          ]
      },
      function(err,docs) {
          // do something here
      }
 )

您收到错误是因为您使用“字符串”覆盖“数组”定义,这是所有“请求”对象的内容,除非另有解析。

错误的另一个原因是你正在调用错误的方法。 .findById()期望文档的_id有一个参数。要查询其他字段,请使用.findOne()或本例.find(),因为$in可能会匹配多个文档。