1

私はマングースが初めてで、集計クエリを使用してデータを取得しようとしているときに問題に直面しています。

私のオークション スキーマの一部は次のとおりです。

  "_id" : ObjectId("56c58be1faaa402c0d4ae66f"),
        "auction_name" : "Auction2",
        "auction_start_datetime" : ISODate("2016-02-18T09:30:00.000Z"),
        "auction_end_datetime" : ISODate("2016-02-22T09:00:00.000Z"),
        "auction_status" : "active",
        "auction_series" : "GA-06-C",
        "auction_reserve_price" : 1000,
        "auction_increment_amount" : 200,
        "fancy_numbers" : [ 
            {
                "number_end_datetime" : ISODate("2016-02-22T09:00:00.000Z"),
                "number_start_datetime" : ISODate("2016-02-18T09:30:00.000Z"),
                "increment_amount" : 200,
                "reserve_price" : 1000,
                "number" : 5000,
                "_id" : ObjectId("56c58da3faaa402c0d4ae739"),
                "bid_users" : [ 
                    {
                        "user_id" : "56c416a599ad7c9c1611b90b",
                        "bid_amount" : 7200,
                        "bid_time" : ISODate("2016-02-18T11:58:53.025Z"),
                        "user_name" : "amit@mailinator.com",
                        "_id" : ObjectId("56c5aec4acebf3b4061a645e")
                    }, 
                    {
                        "user_id" : "56c172dc302a2c90179c7fd1",
                        "bid_amount" : 15400,
                        "bid_time" : ISODate("2016-02-19T10:38:43.506Z"),
                        "user_name" : "rbidder@mailinator.com",
                        "_id" : ObjectId("56c5afe0d2baef7020ede1b6")
                    }, 
                    {
                        "user_id" : "56c477afb27a7ed824c54427",
                        "bid_amount" : 2800,
                        "bid_time" : ISODate("2016-02-18T11:56:58.830Z"),
                        "user_name" : "bidder2@mailinator.com",
                        "_id" : ObjectId("56c5b18a78c3fb340a8c6d75")
                    }, 
                    {
                        "user_id" : "56c5b17378c3fb340a8c6d73",
                        "bid_amount" : 5600,
                        "bid_time" : ISODate("2016-02-18T11:58:34.616Z"),
                        "user_name" : "bidder3@mailinator.com",
                        "_id" : ObjectId("56c5b1d778c3fb340a8c6d78")
                    }
                ]
            }
]

ここで、fancy_number はオークション コレクション配下の配列、bid_users は各 fancy_number 配下の配列です。

私は user_id を持っています。彼が最高入札者であるbid_user レコードのみを照会して取得したいと考えています。

例えば:

それぞれ 200、300、400 で入札された 3 人のユーザーがいます。この特定のユーザーの入札が 400 (最高) の場合にのみ、レコード (つまり、数と金額) を取得したいと考えています。user_id を渡す場所

私が書いた集計クエリは次のとおりです。

var ObjectID = require('mongodb').ObjectID;
tempId = new ObjectID(req.body.aId);

auctionModel.aggregate({$match: {'_id': tempId}},
                        {$unwind: '$fancy_numbers'},
                        {$unwind:"$fancy_numbers.bid_users"},
                        {$group: {'_id':"$fancy_numbers.number" , maxBid: { $max: '$fancy_numbers.bid_users.bid_amount'}}},  
    function(err, bidData){
        if(err){
            console.log('Error :' + err);
        }
        else if(bidData) {
            console.log(bidData);
        }
     });

どういうわけか、このクエリは機能していません。最大入札額と数のレコードのみを提供します。彼が落札者の場合のみ記録が欲しいです。

4

1 に答える 1