MongoDB 2.4添加了一个新的"Limit Number of Elements in an Array after an Update" feature。这是通过shell使用它的方式:
db.students.update(
{ _id: 1 },
{ $push:
{ scores:
{ $each :
[
{ attempt: 3, score: 7 },
{ attempt: 4, score: 4 }
],
$sort: { score: 1 },
$slice: -3
}
}
}
)
如何使用MongoDB的C#-driver完成这项工作?
答案 0 :(得分:5)
以下示例测试显示了如何在不使用类型化类的情况下执行此操作:https://github.com/mongodb/mongo-csharp-driver/blob/master/MongoDB.DriverUnitTests/Builders/UpdateBuilderTests.cs#L492
您正在寻找的相关代码是:
var update = Update.PushEach(
"name",
new PushEachOptions { Slice = -3, Sort = SortBy.Descending("a") },
value1ToPush,
value2ToPush);
如果您使用的是类型化实体,我们也会支持此功能:https://github.com/mongodb/mongo-csharp-driver/blob/master/MongoDB.DriverUnitTests/Builders/UpdateBuilderTests.cs#L524
var update = Update<Test>.PushEach(
x => x.B,
args => args.SortDescending(x => x.C).Slice(-3),
new[] { new B { C = 0 }, new B { C = 1 } });
最后,就像.NET驱动程序中的其他内容一样,您始终可以构建一个看起来与上面的结构完全相同的BsonDocument,并简单地执行它。