0

いくつかの毎日の統計を含むコレクションがあり、mongo で集計フレームワークを使用したいと考えています。今、Integer64 (タイプ 18) を互いにソート/グループ化する際に問題に直面したので、助けを求めたいと思います:

mongos> db.daily_apps_totals.findOne({"_id.appId":{$type:16}})
{
    "_id" : {
            "datetime" : ISODate("2012-08-15T00:00:00Z"),
            "appId" : 243,
            },
    ...
}

mongos> db.daily_apps_totals.aggregate([ {$match: {"_id.datetime":ISODate("2013-01-28T00:00:00Z"), "_id.appId":{$type:16}}},  {$project:{_id:"$_id.appId"}}, {$sort: {_id:1}},{$limit:3}])
{
    "result" : [
            {
                    "_id" : 243
            },
            {
                    "_id" : 243
            },
            {
                    "_id" : 245
            }
    ],
    "ok" : 1
}

Sort は Integer32 (タイプ 16) ではうまく機能しますが、Integer64 ではうまく機能しません。

mongos> db.daily_apps_totals.findOne({"_id.appId":{$type:18}})
{
    "_id" : {
            "datetime" : ISODate("2012-08-15T00:00:00Z"),
            "appId" : NumberLong(245),
    },
    ...
}

mongos> db.daily_apps_totals.aggregate([ {$match: {"_id.datetime":ISODate("2013-01-28T00:00:00Z"), "_id.appId":{$type:18}}},  {$project:{_id:"$_id.appId"}}, {$sort: {_id:1}},{$limit:3}])
{
    "errmsg" : "exception: can't compare values of BSON types Array and NumberLong64",
    "code" : 16016,
    "ok" : 0
}

PS MongoDB シェル バージョン: 2.2.1

4

1 に答える 1