Геопространственный запрос MongoDB с $ not

У меня есть базовый геопространственный запрос, хорошо работающий в MongoDB. Кажется, было бы легко применить $, чтобы не получить дополнение ... но у меня это не работает. Это простая ошибка пользователя? Или MongoDB может не обрабатывать этот запрос концептуально? Я не нашел такого ограничения в документации .

Рабочий запрос (правильно находит 2 города в пределах 10 миль от центра):

db.customers.find({ "location" : { $within : { $center : [[-117.15,32.72],0.15] } } })

Попытка дополнить запрос (желаемый результат - 1 город, который находится за пределами 10 миль):

db.customers.find({ "location" : { $not : { $within : { $center : [[-117.15,32.72],0.15] } } } })
error: {
    "$err" : "missing geo field (location) in : {location: { $not: { $within: { $center: [ [ -117.15, 32.72 ], 0.15 ] } } } }",
    "code" : 13042
}

Для всех, кто хочет скопировать / вставьте запрос, чтобы увидеть ошибку, вот небольшой фрагмент данных примера:

db.customers.ensureIndex( { "location" : "2d" } )
db.customers.save({"city":"La Mesa","state":"CA","location":[ -117.02,32.76 ]})
db.customers.save({"city":"Chula Vista","state":"CA","location":[ -117.08,32.63 ]})
db.customers.save({"city":"Mexico City","state":"Mexico","location":[-99.133244,19.4326]})

(Я использую MongoDB 1.8.2 на случай, если это имеет значение.)

8
задан mdahlman 14 November 2011 в 18:07
поделиться