Mongo索引 - Nodejs

时间:2012-09-29 15:04:45

标签: node.js mongodb mongoose

我使用以下架构和代码在Mongo中创建集合以及Indexer并插入数据。请注意,该集合是基于categoryName动态创建的。

var employeeSchema = new mongoose.Schema({

      categoryId              : {type: String, required: true },

      loc                     : {type: {lon: Number,  lat: Number}, index: '2d'},

     // createdBy             : {type: String, required: true },
      createDate              : {type: Date, default: Date.now}
});

exports.register = function   (objEmployee , callback)
{
            var emp = db.model(objEmployee.categoryName, employeeSchema );

            var objSchema = new emp(objEmployee);          
            objSchema.save(function (err) {
            if (err) return callback(err);
            console.info ('Data inserted successfully.');
            return callback(null);
            });

};

我能够插入数据但是当我根据radious运行查询时,当我运行时出现以下错误。

Sat Sep 29 20:21:24 uncaught exception: error: {
    "$err" : "can't find special index: 2d for: { loc: { $within: { $center: [ [ 50.9393925139, -114.0 ], 2.0 ] } } }",
    "code" : 13038

我的代码出了什么问题?

1 个答案:

答案 0 :(得分:3)

我认为你的loc的架构定义是错误的。它应该是

loc: {
  lon: Number,
  lat: Number
}

在架构定义之后添加索引

employeeSchema.index({
  loc: "2d"
});