MongoDB 3.0.2.Примеры документов:
{ "_id" : NumberLong(1), Categories : { "123" : { "Shows" : NumberLong(7), "Clicks" : NumberLong(0) }, "221" : { "Shows" : NumberLong(33), "Clicks" : NumberLong(12) } } }
{ "_id" : NumberLong(2), Categories : { "221" : { "Shows" : NumberLong(33), "Clicks" : NumberLong(12) } } }
{ "_id" : NumberLong(3), Categories : { "123" : { "Shows" : NumberLong(8), "Clicks" : NumberLong(1) } } }
{ "_id" : NumberLong(4), Categories : { "99" : { "Shows" : NumberLong(144), "Clicks" : NumberLong(39) }, "221" : { "Shows" : NumberLong(52), "Clicks" : NumberLong(2) } } }
{ "_id" : NumberLong(5), Categories : { "95" : { "Shows" : NumberLong(18), "Clicks" : NumberLong(3) } } }
{ "_id" : NumberLong(6), Categories : { "123" : { "Shows" : NumberLong(89), "Clicks" : NumberLong(69) } } }
В моем случае в этом примере строковые значения, такие как "123", "221", "99", "95", являются идентификаторами некоторых категорий.Мне нужна сортировка только по Показывает с использованием идентификатора категории:
db.myCollection.find().sort( Categories."1".Shows : -1 )
db.myCollection.find().sort( Categories."95".Shows : 1 )
db.myCollection.find().sort( Categories."123".Shows : 1 )
db.myCollection.find().sort( Categories."221".Shows : -1 )
Но количество этих категорий составляет около 250+.Я не могу установить индексы для каждого, например:
db.myCollection.createIndex( { Categories."[1..250]".Shows : 1 } );
, потому что для идентификатора кошки более 64 (предел MongoDB), и эти категории можно добавлять и удалять только для некоторых записей, и этот процесс динамический.
Без индексов я получаю:
Неполное исключение 'MongoCursorException' с сообщением 'localhost: 27017: Ошибка исполнителя: использование буферизованных данных на этапе сортировки переполнения 33554646 байт превышает внутренний предел 33554432 байт' в ..
Может кто-нибудь дать решение по этому делу?