我有以下文件名为Attendances
{
"_id" : ObjectId("5a4ffb00762caf6b54f61ebb"),
"AttnDate" : ISODate("2018-01-05T22:24:00.490Z"),
"AllAttendances" : [
{
"FullName" : "DOMAIN\Zack",
"Logged" : ISODate("2018-01-05T22:23:46.835Z"),
"Pauses" : [
{
PauseStartAt: ISODate("2018-01-05T22:30:46.835Z"),
PauseEndAt: ISODate("2018-01-05T22:35:46.835Z")
}
]
}
]
}
如何将新项目添加到暂停。这是我的尝试,但我有这个错误“无法将lambda表达式转换为类型'fielddefinition,因为它不是委托类型。
我的尝试
var filter = Builders<Attendance>.Filter.Eq(a => a.Id, currentAttn.Id) & Builders<Attendance>.Filter.ElemMatch(s => s.AllAttendances, Builders<TimeRecord>.Filter.Eq(n => n.FullName, userName));
var update = Builders<Attendance>.Update.Push(e => e.AllAttendances[-1].Pauses, pauses);
context.Attendances.FindOneAndUpdate(filter, update);
我遵循了guide
出勤班
public class Attendance
{
[JsonConverter(typeof(ObjectIdConverter))]
public ObjectId Id { get; set; }
[BsonDateTimeOptions(Kind = DateTimeKind.Local)]
public DateTime AttnDate { get; set; }
public List<TimeRecord> AllAttendances { get; set; }
}
TimeRecord Class(AllAttendances)
public class TimeRecord
{
public string FullName { get; set; }
[BsonDateTimeOptions(Kind = DateTimeKind.Local)]
public DateTime Logged { get; set; }
public List<Pause> Pauses { get; set; }
}
暂停课程
public class Pause
{
[BsonDateTimeOptions(Kind = DateTimeKind.Local)]
public DateTime PauseStartedAt { get; set; }
[BsonDateTimeOptions(Kind = DateTimeKind.Local)]
public DateTime PauseEndedAt { get; set; }
}
答案 0 :(得分:0)
您需要将过滤器更新为
var filter = Builders<Attendance>.Filter.Eq(a => a.Id, id) &
Builders<Attendance>.Filter.ElemMatch(s => s.AllAttendances, x => x.FullName == userName);
ElemMatch
的第一个参数是字段,第二个参数是过滤器。
答案 1 :(得分:0)
从不同的角度来看,我建议你不要在c#中使用ObjectID。我总是将ObjectIds定义为模型中的字符串,并使用Bson属性修饰符将它们定义为数据库中的ObjectId
[BsonId]
[BsonRepresentation(BsonType.ObjectId)]
public string Id { get; set; }
纯粹是因为在C#中尝试使用ObjectIds导致的痛苦。字符串更容易处理。您在mongodb中的文档仍然看起来一样,您根本不需要在代码中强制转换为对象ID:
_id : ObjectId("xxxxxxx")
这可以帮助您解决编译器不知道如何进行转换的问题