MongoDB - найти все документы, где размер массива / списка больше N
Просмотрите следующие документы:
Коллекция: домен
{ "_id" : 1001, "domainName" : "google.com" "tag" : [ "search engine", "search", "find anything", "giant" ] }, { "_id" : 1002, "domainName" : "yahoo.com" "tag" : [ "search engine", "online portal", ] }, { "_id" : 1003, "domainName" : "example.com" }
1. Вопрос
Как найти все документы, где размер «тега» больше 3?
# 1.1 Попробуйте объединить$size
и$gt
следующим образом:
db.domain.find( { tag: {$size: {$gt:3} } } ); null
Нет ошибки, но он всегда будет возвращать ноль, кажется, MongoDB не работает, как это.
# 1.2 Попробуйте использовать оператор$where
.
db.domain.find( {$where:'this.tag.length>3'} ) MongoDB v 2.2.3 uncaught exception: error { "$err" : "error on invocation of $where function:\nJS Error: TypeError: this.tag has no properties nofile_a:0", "code" : 10071 } or MongoDB v 2.4.5 JavaScript execution failed: error: { "$err" : "JavaScript execution failed: TypeError: Cannot read property 'length' of undefined near '' ", "code" : 16722 } at src/mongo/shell/query.js:L128 >
Похоже, оператор$where
тоже не работает?
2. Решение
На самом деле оператор$where
работает нормально, просто не все документы содержат поле «тег» и вызвали ошибку «нет свойств».
2.1 To fix it, try combine $exists
and $where
together :
db.domain.find( {tag : {$exists:true}, $where:'this.tag.length>3'} ) { "_id" : 1001, "domainName" : "google.com" "tag" : [ "search engine", "search", "find anything", "giant" ] }