簡體   English   中英

使用C#選擇MongoDB集合中所有用戶的最后N個文檔

[英]Select Last N documents of all Users in MongoDB Collection using C#

我有一個MongoDB集合,我需要使用C#MongoDB查詢選擇每個員工(Emp_ID)的最后3個文檔(按降序LastUpdate排序)。

樣品采集:

{
    "_id" : ObjectId("575f4e2efd14481598fc0ebf"),
    "Emp_ID" : "100",
    "LastUpdate" : ISODate("2016-06-13T18:30:00.000Z")
},
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec0"),
    "Emp_ID" : "101",
    "LastUpdate" : ISODate("2016-06-14T06:33:12.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec1"),
    "Emp_ID" : "101",
    "LastUpdate" : ISODate("2016-06-14T06:33:16.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec2"),
    "Emp_ID" : "102",
    "LastUpdate" : ISODate("2016-06-14T06:33:18.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec3"),
    "Emp_ID" : "100",
    "LastUpdate" : ISODate("2016-06-14T06:33:26.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec3"),
    "Emp_ID" : "102",
    "LastUpdate" : ISODate("2016-06-14T06:33:29.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec4"),
    "Emp_ID" : "101",
    "LastUpdate" : ISODate("2016-06-14T06:34:18.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec5"),
    "Emp_ID" : "102",
    "LastUpdate" : ISODate("2016-06-14T06:34:20.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec6"),
    "Emp_ID" : "100",
    "LastUpdate" : ISODate("2016-06-14T06:34:31.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec7"),
    "Emp_ID" : "102",
    "LastUpdate" : ISODate("2016-06-14T06:34:35.000Z")
}
,
{
    "_id" : ObjectId("575f4e2efd14481598fc0ec8"),
    "Emp_ID" : "101",
    "LastUpdate" : ISODate("2016-06-14T06:34:38.000Z")
}

我知道要選擇一個員工信息

實驗查詢:

var collection = _database.GetCollection<Employee>("EmpInfo");
var filterBuilder = Builders<Employee>.Filter;
var filter = filterBuilder.Eq("Emp_ID", "100");
var Item = collection.Find(filter)
                     .Sort(Builders<Employee>.Sort.Descending("LastUpdate"))
                     .Limit(3).ToList();

請協助我,如何使用C#MongoDB查詢從上述集合中選擇每位員工的最后3條記錄(我更喜歡單查詢執行)。

數據使用的好例子!

為了實現這一點,我們需要使用聚合, $match按日期限制要采取行動的元素數量,然后$sort按日期值降序對數據進行$sort$group group-按員工ID對記錄進行分組,最后將$project slices數組結果,只給我們三個冷杉職位。

startDate僅用作數據限制器-但在現實生活中,您也應該使用它:-)

    startDate = new Date() // Current date
    startDate.setDate(startDate.getDate() - 7) // Subtract 7 days


    db.irpunch.aggregate([{
                $match : {
                    LastUpdate : {
                        $gte : startDate
                    }
                }
            }, {
                $sort : {
                    LastUpdate : -1
                }
            }, //sort data
            {
                $group : {
                    _id : "$Emp_ID",
                    documents : {
                        $push : "$$ROOT"
                    }
                }
            }, {
                $project : {
                    _id : 1,
                    documents : {
                        $slice : ["$documents", 3]
                    }
                }
            }
        ])

編輯

public static void Main()
{
    var client = new MongoClient("mongodb://localhost:27017");
    var database = client.GetDatabase("test");

    var collection = database.GetCollection<InnerDocument>("irpunch");


    var aggregationDocument = collection.Aggregate()
        .Match(x=>x.LastUpdate> DateTime.Now.AddDays(-40))
        .SortByDescending(x => x.LastUpdate)
        .Group(BsonDocument.Parse("{ _id:'$Emp_ID', documents:{ '$push':'$$ROOT'}}"))
        .Project<AggregationResult>(BsonDocument.Parse("{ _id:1, documents:{ $slice:['$documents', 3]}}")).ToList()
        ;

    foreach (var aggregationResult in aggregationDocument)
    {
        foreach (var innerDocument in aggregationResult.documents)
        {
            Console.WriteLine($"empID: {aggregationResult._id}, doc date: {innerDocument.LastUpdate}");
        }
        Console.WriteLine();
    }

    Console.ReadLine();
}


public class AggregationResult
{
    public int _id { get; set; }
    public InnerDocument[] documents { get; set; }
}

public class InnerDocument
{
    public ObjectId Id { get; set; }
    public string Emp_ID { get; set; }
    public DateTime LastUpdate { get; set; }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM