在聚合查询中使用$ match

时间:2014-12-02 19:43:55

标签: regex mongodb mongodb-query aggregation-framework

我在Mongodb中有这些值:

{
"_id" : ObjectId("4feb9d573752c8a33a000001"),
"name" : "TSP1",
"Server" : "S1",
"active" : true,
"tag" : "<A HREF=\"[FAST_1]http://www.google.com"><IMG SRC=\"http://ad.google.com.CO/B5981883.7;sz=300x50;ord=[TIMESTAMP]?\" BORDER=0 WIDTH=300 HEIGHT=50 ALT=\"ment\"></A>"
},
{
"_id" : ObjectId("4feb9d573752c8a33a000001"),
"name" : "TSP2",
"Server" : "S1",
"active" : true,
"tag" : "<A HREF=\"[FAST_1]http://www.google.com"><IMG SRC=\"http://ad.ITG.com.CO/B5981883.7;sz=300x50;ord=[TIMESTAMP]?\" BORDER=0 WIDTH=300 HEIGHT=50 ALT=\"ment\"></A>"
}
{
"_id" : ObjectId("4feb9d573752c8a33a000003"),
"name" : "TSP3",
"Server" : "S2",
"active" : true,
"tag" : "<A HREF=\"[FAST_2]http://www.google.com"><IMG SRC=\"http://ad.Yahoo.com.CO/B5981883.7;sz=300x50;ord=[TIMESTAMP]?\" BORDER=0 WIDTH=300 HEIGHT=50 ALT=\"ment\"></A>"
}

我想把这个结果拿出来:

    "result" : [
    {
        "_id" : "S1",
        "count" : 2
    }]

这是我正在使用的查询:

db.creative.aggregate([ { $match : { tag : { $regex : /[FAST_1]/ } }}, { $group: { _id : "$Server", count: { $sum: 1} }} ]);

另外,试过这个:

db.creative.aggregate([ {$match : {"tag" : /[FAST_1]/ }}, { $group: { _id : "$Server", count: { $sum: 1}}} ])

但我一直得到这个结果:

    {
        "_id" : "S1",
        "count" : 2
    },
    {
        "_id" : "S2",
        "count" : 1
    }

即使我将FAST_1更改为FAST_2,我也会得到相同的结果。

感谢任何帮助。

由于

1 个答案:

答案 0 :(得分:1)

你需要绕着大括号[]来逃避正则表达式。

db.creative.aggregate([ { $match : { tag : { $regex : /\[FAST_1\]/ } }},  ...