使用Regex在mongodb聚合中找不到匹配的Number

时间:2016-10-04 06:45:38

标签: node.js regex mongodb mongodb-query aggregation-framework

我有一个集合

//演示名称:user_informations

  {
        "_id" : 3015,
        "Phone Number" : "9159571195",
        "First Name" : "logesh",
        "Last Name" : "chandiran",
        "Email ID" : "logu@gmail.com",
        "Gender" : "male",
        "customerID" : "CUST3015",
        "createddate" : 1472482064363.0,
        "modifieddate" : 1474384997049.0,
        "transationHistory" : [ 
            {
                "transactionStatus" : "Success",
                "transactionAmount" : 2500,
                "paymentId" : "Q8urVX9Cpf",
                "transactionDate" : 1472754600000.0,
                "transactionId" : "7egsOpmqBR",
                "comments" : "EMI",
                "medium" : "Cash"]
            }
    }

我正在使用以下查询

db.user_informations.aggregate([
           {
            $match:{"Phone Number": '9159571195'}},
            {$unwind:'$transationHistory'},
            {"$match":{"$or":[
            {"transationHistory.transactionAmount":{$regex:/2500/i}},
            {"transationHistory.transactionId":{$regex:/2500/i}},
            {"transationHistory.paymentId":{$regex:/2500/i}},
            {"transationHistory.transactionStatus":{$regex:/2500/i}},
            {"transationHistory.medium":{$regex:/2500/i}},
            {"transationHistory.comments":{$regex:/2500/i}}
            ]}},
            {"$group":{_id: null,"count":{$sum: 1 },"result":{$push:"$transationHistory"}}}

         ])

以上查询可以正常使用字符串中的值,但不能使用返回为null的数字。如何将值与集合字段中的数字匹配。 我需要从集合中匹配数据的计数和结果。

2 个答案:

答案 0 :(得分:0)

正则表达式是字符串的工具,而不是数字。使用常规数字比较运算符,例如$eq$gt$lt等。

基本上,它将是:

db.user_informations.aggregate(
    {$match:{"Phone Number": '9159571195'}},
    {$unwind:'$transationHistory'},
    {"$match":{
        "$or":[
            {"transationHistory.transactionAmount":{$eq:2500}}
        ]
    },
    {"$group":{
        _id: null,
        "count":{$sum: 1 },
        "result":{$push:"$transationHistory"}
    }})

希望所有括号都到位。

答案 1 :(得分:0)

db.user_informations.aggregate(
    {$match:{"Phone Number": '9159571195'}},
    {$unwind:'$transationHistory'},
{$project:{
            "transactionAmount":{ "$toLower":"$transationHistory.transactionAmount"}                            
            }},
    {"$match":{
        "$or":[
             {"transactionAmount":{$regex:txt,"$options": "i"}}
        ]
    },
    {"$group":{
        _id: null,
        "count":{$sum: 1 }
    }})