2017-01-20 10 views
9

Мне нужно интегрировать поиск миль/расстояний на моем сайте, и я использую геопространственные индексы 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 

Пожалуйста, помогите мне решить эту ошибку.

ответ

20

Потребность db.adminCommand({ setFeatureCompatibilityVersion: "3.4" })

+0

'' 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', как упоминалось в этой ссылке. –

+0

Попробуйте удалить 2d по индексу 2dsphere. И добавьте в свой запрос 'сферический: истинный'. Он должен работы: 'db.properties.aggregate ([ { $ geoNear: { вблизи: {типа: "Точка", координаты: [-2,94379156655216, 54,8905641133194]}, distanceField: "dist.calculated", maxDistance : 2, includeLocs: "dist.location", NUM: 5, сферическая: истинные }} ]) ' –

+0

работал для меня, спасибо – AhammadaliPK

0

Используйте это в Монго оболочки

db.adminCommand({ setFeatureCompatibilityVersion: "3.4" }) 
+0

Это то же самое, как принято отвечать. – SymbolixAU