2

这似乎是一个常见错误,但我似乎无法让它与我看到的所有建议一起工作。这是我的设置:

// point.js (based on mongoose recommended subdocument pattern for reusing the GeoJSON definition
// see here https://mongoosejs.com/docs/geojson.html)
const mongoose = require('mongoose');

const pointSchema = new mongoose.Schema({
    type: {
        type: String,
        enum: ['Point'],
        required: true
    },
    coordinates: {
        type: [Number],
        required: true,
    }
});

exports = pointSchema;
// user.js
var schema = new Schema({
  location: {
    type: pointSchema,
  },
  ...
});

schema.index({ location: '2dsphere' });
var User = mongoose.model('User', schema);
// routeHandler.js
          const near = { type: 'Point', coordinates: [lng, lat] };
          User.aggregate([
            { $geoNear: {
              near,
              distanceField: 'dist',
              maxDistance: 100000,
              spherical: true,
            } },
            ...
          ]).exec((err, results) => {
            console.log('error or results:', err, results);
          });

我得到这个错误:

MongoError:无法确定查询系统是否可以提供由 :: geo 引起的覆盖投影 :: 在查询 GeoJSON 点时仅接受一个参数。发现额外字段:$maxDistance:100000.0

我见过的大多数线程都表明这是索引的问题,但您可以看到user.js我直接调用

schema.index({ location: '2dsphere' });

没有任何运气。

我真的很感激任何建议,谢谢!

4

2 回答 2

2

我遇到了同样的问题并经历了许多解决方案,但其中任何一个都不起作用,因为 真正的问题在于 data

在我的模型中,2dsphere 索引是正确的,但是当使用 2dshpere 时,数据库中的位置应该是 location 格式:[ lng, lat ],这是主要问题。因为 mongodb 不验证位置数组这种格式。

验证 DB 中的数据和查询时指定的点都应该是正确的格式。

希望它可以帮助某人!

于 2021-04-14T12:37:08.887 回答
0

我也遇到了同样的错误,经过大量研究后,我发现运行聚合查询的错误。我将坐标作为字符串数组传递,它应该是一个数字数组。

{
        $geoNear: {
          near: {
            type: "Point",
            coordinates: [103.83797, 1.46103],
          },
          distanceField: "dist.calculated",
          maxDistance: distance,
          includeLocs: "dist.location",
          spherical: true,
        },
      },
于 2022-02-05T15:44:58.547 回答