MongoDB не равно - PullRequest
       3

MongoDB не равно

89 голосов
/ 20 марта 2012

Я пытаюсь отобразить запрос в MongoDB, где текстовое поле не '' (пусто)

{ 'name' : { $not : '' }}

Однако я получаю ошибку invalid use of $not

Я просмотрел документацию, но примеры, которые они используют, предназначены для сложных случаев (с регулярным выражением и $not с отрицанием другого оператора).

Как бы я сделал простую вещь, которую я пытаюсь сделать?

Ответы [ 6 ]

129 голосов
/ 20 марта 2012

Использование $ne - $not должно сопровождаться стандартным оператором:

Примеры для $ne, что означает не равно:

use test
switched to db test
db.test.insert({author : 'me', post: ""})
db.test.insert({author : 'you', post: "how to query"})
db.test.find({'post': {$ne : ""}})
{ "_id" : ObjectId("4f68b1a7768972d396fe2268"), "author" : "you", "post" : "how to query" }

А теперь $not, который принимает предикат ($ne) и отрицает его ($not):

db.test.find({'post': {$not: {$ne : ""}}})
{ "_id" : ObjectId("4f68b19c768972d396fe2267"), "author" : "me", "post" : "" }
59 голосов
/ 11 июля 2013

Если вы хотите сделать несколько $ne, тогда сделайте

db.users.find({name : {$nin : ["mary", "dick", "jane"]}})
33 голосов
/ 20 марта 2012

Используйте $ne вместо $not

http://docs.mongodb.org/manual/reference/operator/ne/#op._S_ne

db.collections.find({"name": {$ne: ""}});
8 голосов
/ 06 февраля 2016

Из документов Монго :

Оператор $not влияет только на других операторов и не может проверять поля и документы самостоятельно. Итак, используйте оператор $not для логические дизъюнкции и оператор $ne для проверки содержимого поля напрямую.

Поскольку вы тестируете поле напрямую, $ne - правильный оператор для использования здесь.

Edit:

Ситуация, в которой вы хотели бы использовать $not:

db.inventory.find( { price: { $not: { $gt: 1.99 } } } )

Это выберет все документы, где:

  • Значение поля цены меньше или равно 1,99 или цена
  • Поле не существует
2 голосов
/ 02 мая 2017

Если в массиве есть null и вы хотите его избежать:

db.test.find({"contain" : {$ne :[] }}).pretty()
0 голосов
/ 16 сентября 2014

Пример из реальной жизни;найти всех, кроме текущего пользователя:

var players = Players.find({ my_x: player.my_x,  my_y: player.my_y, userId: {$ne: Meteor.userId()} }); 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...