Мне нужно интегрировать поиск миль/расстояний на моем сайте, и я использую геопространственные индексы mongodb, однако я получаю некоторые и не могу решить. Ниже моя схема и командаФункцияCompatibilityVersion должна быть 3.4 для использования сортировки
=> db.properties.findOne({},{address:1})
{
"_id" : ObjectId("585b909c870d907845b695fd"),
"address" : {
"postcode" : "W1D 1NN",
"address1" : "Essence",
"address2" : "United Kingdom House",
"county" : "London",
"town" : "LONDON",
"latitude" : "51.5160229933117",
"longitude" : "-0.139088472429092",
"house_number" : "114",
"location" : {
"type" : "Point",
"coordinates" : [
-0.139088472429092,
51.5160229933117
]
}
}
}
Ниже мои индексы
=> db.properties.getIndexes()
[
{
"v" : 1,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "cherrydoorsync.properties"
},
{
"v" : 1,
"key" : {
"address.location.coordinates" : "2d"
},
"name" : "address.location.coordinates_2d",
"ns" : "cherrydoorsync.properties"
}
]
Однако, когда я выполнить следующую команду в Монго оболочки, я получаю ошибки
db.properties.aggregate([
{
$geoNear: {
near: { type: "Point", coordinates: [ -2.94379156655216, 54.8905641133194 ] },
distanceField: "dist.calculated",
maxDistance: 2,
includeLocs: "dist.location",
num: 5
}
}
])
ошибка:
assert: command failed: {
"ok" : 0,
"errmsg" : "geoNear command failed: { ok: 0.0, errmsg: \"The featureCompatibilityVersion must be 3.4 to use collation. See http://dochub.mongodb.org/core/3.4-feature-compatibility.\", code: 72, codeName: \"InvalidOptions\" }",
"code" : 16604,
"codeName" : "Location16604"
} : aggregate failed
[email protected]/mongo/shell/utils.js:25:13
[email protected]/mongo/shell/assert.js:16:14
[email protected]/mongo/shell/assert.js:370:5
[email protected]/mongo/shell/collection.js:1319:5
@(shell):1:1
2017-01-20T13:41:27.914+0530 E QUERY [main] Error: command failed: {
"ok" : 0,
"errmsg" : "geoNear command failed: { ok: 0.0, errmsg: \"The featureCompatibilityVersion must be 3.4 to use collation. See http://dochub.mongodb.org/core/3.4-feature-compatibility.\", code: 72, codeName: \"InvalidOptions\" }",
"code" : 16604,
"codeName" : "Location16604"
} : aggregate failed :
[email protected]/mongo/shell/utils.js:25:13
[email protected]/mongo/shell/assert.js:16:14
[email protected]/mongo/shell/assert.js:370:5
[email protected]/mongo/shell/collection.js:1319:5
@(shell):1:1
Существует t он связать (http://dochub.mongodb.org/core/3.4-feature-compatibility) в сообщении об ошибке и я по этой ссылке, ему предлагают установить setFeatureCompatibilityVersion to "3.4".
, я запустить эту команду и снова получать некоторую другую ошибку
> db.adminCommand({ setFeatureCompatibilityVersion: <"3.4" })
2017-01-20T13:45:39.023+0530 E QUERY [main] SyntaxError: expected expression, got '<' @(shell):1:51
Пожалуйста, помогите мне решить эту ошибку.
'' db.adminCommand ({setFeatureCompatibilityVersion: "3,4"}) '' команда выполняется успешно, теперь удалены "featureCompatibilityVersion" ошибка и бросить другая ошибка '' '' errmsg ":" команда geoNear не выполнена: {ok: 0.0, errmsg: \ "не может получить запрос-исполнитель \"} ", \t" код ": 16604, \t" codeName ":" Location16604 "' '' Я проверил эту ссылку (h ttp: //stackoverflow.com/questions/30240883/mongodb-cant-get-query-executor-when-executing-geonear-aggregate), но у меня есть только один индекс '2d' не' 2dsphere', как упоминалось в этой ссылке. –
Попробуйте удалить 2d по индексу 2dsphere. И добавьте в свой запрос 'сферический: истинный'. Он должен работы: 'db.properties.aggregate ([ { $ geoNear: { вблизи: {типа: "Точка", координаты: [-2,94379156655216, 54,8905641133194]}, distanceField: "dist.calculated", maxDistance : 2, includeLocs: "dist.location", NUM: 5, сферическая: истинные }} ]) ' –
работал для меня, спасибо – AhammadaliPK