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), и эти категории могут быть добавлены и удалены только для некоторых записей, и этот процесс динамический.
Без индексов я получаю:
Uncaught exception 'MongoCursorException' with message 'localhost:27017: Executor error: Overflow sort stage buffered data usage of 33554646 bytes exceeds internal limit of 33554432 bytes' in ..
Может кто подскажет решение для этого случая?

Я не думаю, что вы сможете решить эту проблему, используя ваш текущий дизайн документа.
Возможно, вы захотите смоделировать свои категории по-другому, например используя массив для категорий вроде этого:
{
"_id" : 1,
"Categories": [
{
"CategoryId": "123",
"Details": {
"Shows": 7,
"Clicks": 0
}, {
"CategoryId": "221",
"Details": {
"Shows": 33,
"Clicks": 12
}
}
]
}
В этом случае вы легко можете добавить единый индекс db.collection.createIndex({"Categories.Details.Shows": 1}).
@DoanldF Мне очень жаль, что это была моя ошибка. Я ошибся в поле. Но да, с этим дизайном вы также можете сделать индекс для Shows.
Using a slightly modified version of dnickless's schema as shown below:
{
"_id" : 1,
"Categories": [
{
"CategoryId": "123",
"Shows": 7,
"Clicks": 0
},
{
"CategoryId": "221",
"Shows": 33,
"Clicks": 12
}
]
}
You could then create an index on shows.
db.collection.createIndex({"Categories.Shows": 1})
Но в этом случае я все еще не могу добавить индексы для полей «Показывает». Мне нужно отсортировать по «Выставкам» для каждой категории. Для вашего варианта дизайна db.myCollection.find ({"Categories.CategoryId": "123"}). Sort ("Categories.Details.Shows": -1) - "Shows" не индексируется.