1

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”这样的字符串值是一些类别的id。我只需要使用类别 ID按节目排序:

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 } );

因为 cat id 超过 64(MongoDB 限制),并且这个类别可以添加和删除到一些记录,这个过程是动态的。

没有索引我得到:

在..

有人可以为这种情况提供解决方案吗?

4

2 回答 2

0
使用稍微修改过的 dnickless 架构版本,如下所示:
{
    “_id”:1,
    “类别”:[
        {
            "CategoryId": "123",
            “节目”:7,
            “点击次数”:0
        },
        {
            "CategoryId": "221",
            “节目”:33,
            “点击次数”:12
        }
    ]
}

然后,您可以为节目创建索引。
db.collection.createIndex({"Categories.Shows": 1})
于 2018-09-20T01:04:50.463 回答
0

我认为您无法使用当前的文档设计来解决此问题。

您可能希望以不同的方式对您的类别进行建模,例如,为类别使用数组,如下所示:

{
    "_id" : 1,
    "Categories": [
        {
            "CategoryId": "123",
            "Details": {
                "Shows": 7,
                "Clicks": 0
        }, {
            "CategoryId": "221",
            "Details": {
               "Shows": 33,
               "Clicks": 12
            }
        }
    ]
}

在这种情况下,您可以轻松添加单个索引db.collection.createIndex({"Categories.Details.Shows": 1})

于 2018-09-19T20:13:22.983 回答