Не вдається отримати всі документи Mongo з запитом - лише деякі повертаються

У мене виникають проблеми з виходом усіх документів, які відповідають запиту на MongoDB. Я використовую PHP.

Ось короткий тест:

## Document 1   

{
   "_id": ObjectId("4ea80a1eb73e26ef1500cc9e"),
   "search": {
   "0": "clothing",
   "1": "golden",
    ....etc

## Document 2
{
   "_id": ObjectId("4ea81e78b73e26ef15339c65"),
   "search": {
     "0": "and",
     "1": "belt",
     "2": "brown",
     "3": "golden",
    ...etc

## query
$search = array('golden');
$products = Products::all( array('search'=>array('$in'=> $search )))//only document 1 is returned.
//this is a quick test. in the end I'd like to have:
$search = array('golden', 'belt'); //document 2 is returned

Документи створюються з масиву PHP, причому "пошук" - це відсортований і єдиний масив елементів рядка:     сортувати ($ пошук);     $ search = array_unique ($ search);

$new->setProperty('search', $search);

Мені дуже подобається Монго, але я не розумію, чому, якщо синтаксис мого документа не правильний, тоді він повертається, а не ні.

Дякую.

0

1 Відповіді

Я не знаю, що в PHP, але це працює:

> db.items.find({})
{ "_id" : ObjectId("4ea98d0fa287fedc0281feee"), "name" : "first", "keywords" : [ "one", "two", "three", "four" ] }
{ "_id" : ObjectId("4ea98d1aa287fedc0281feef"), "name" : "first", "keywords" : [ "two", "three", "four", "five" ] }
{ "_id" : ObjectId("4ea98d23a287fedc0281fef0"), "name" : "first", "keywords" : [ "four", "five", "six" ] }
{ "_id" : ObjectId("4ea99243a287fedc0281fef1"), "name" : "first", "keywords" : [ "five", "six" ] }
{ "_id" : ObjectId("4ea99247a287fedc0281fef2"), "name" : "first", "keywords" : [ "five", "six", "seven" ] }
{ "_id" : ObjectId("4ea99273a287fedc0281fef3"), "name" : "first", "keywords" : [ "one", "two", "seven" ] }
{ "_id" : ObjectId("4ea9927aa287fedc0281fef4"), "name" : "first", "keywords" : [ "one", "two", "seven" ] }
> db.items.find({$or:[{keywords:"four"},{keywords:"five"}]})
{ "_id" : ObjectId("4ea98d0fa287fedc0281feee"), "name" : "first", "keywords" : [ "one", "two", "three", "four" ] }
{ "_id" : ObjectId("4ea98d1aa287fedc0281feef"), "name" : "first", "keywords" : [ "two", "three", "four", "five" ] }
{ "_id" : ObjectId("4ea98d23a287fedc0281fef0"), "name" : "first", "keywords" : [ "four", "five", "six" ] }
{ "_id" : ObjectId("4ea99243a287fedc0281fef1"), "name" : "first", "keywords" : [ "five", "six" ] }
{ "_id" : ObjectId("4ea99247a287fedc0281fef2"), "name" : "first", "keywords" : [ "five", "six", "seven" ] }
> db.items.find({keywords:{$in:["four","five"]}})
{ "_id" : ObjectId("4ea98d0fa287fedc0281feee"), "name" : "first", "keywords" : [ "one", "two", "three", "four" ] }
{ "_id" : ObjectId("4ea98d1aa287fedc0281feef"), "name" : "first", "keywords" : [ "two", "three", "four", "five" ] }
{ "_id" : ObjectId("4ea98d23a287fedc0281fef0"), "name" : "first", "keywords" : [ "four", "five", "six" ] }
{ "_id" : ObjectId("4ea99243a287fedc0281fef1"), "name" : "first", "keywords" : [ "five", "six" ] }
{ "_id" : ObjectId("4ea99247a287fedc0281fef2"), "name" : "first", "keywords" : [ "five", "six", "seven" ] }
0
додано
Спробував так, дотепер немає долі: $ products = Products :: all (array ('$ or' => array (масив ('search' => "golden")))); - повертаються лише деякі документи, але не документ 2.
додано Автор koichirose, джерело
Це буде так само, якщо я виконую запит у оболонці або через веб-адміністратора, як RockMongo
додано Автор koichirose, джерело
Ukrainian PHP comunity
Ukrainian PHP comunity
885 учасників

dev-ua/php