我正在寻找在mongodb中过滤日期时间字段的方法。这似乎非常简单,但我无法在网站或谷歌搜索中找到任何关于此的文档。
Bson文件
{
"_id" : ObjectId("560cd175c771472d780aab3c"),
"BDay" : ISODate("2005-12-22T18:00:00.000Z"),
"AddressID" : 987,
"Age" : 58,
"Father" : {
"BDay" : {
"_csharpnull" : true
},
"AddressID" : 0,
"Age" : 31,
"Father" : null,
"ID" : "6e2a9c3b-091a-4171-843e-6cbd0994bfda",
"Income" : 26794.0000000000000000,
"Name" : "YLM66LF3",
"_id" : ObjectId("000000000000000000000000")
},
"ID" : "707080e6-8705-48b1-8471-f7af58be6d11",
"Income" : 5734.0000000000000000,
"Name" : "XVCDFKF8"
}
我的守则如下。
var collection = cdb.GetCollection<BsonDocument>("person");
var bday= new DateTime(2015, 12, 22, 18, 00, 00).ToLocalTime();
var s = BsonValue.Create(beginTime);
var filter = Builders<BsonDocument>.Filter.Gte("BDay", s);
var result = await collection.Find(filter).ToListAsync();
我尝试了其他方法,但都没有成功。
答案 0 :(得分:1)
根据API Document,Filter.Gte
方法的参数为FieldDefinition<TDocument, TField>, TField
。
由于FieldDefinition<TDocument, TField>
是一个抽象类,所以应该有一个子类。
我的Gte
查询示例如下:
(假设您的beginTime
是DateTime
值)
var filter = Builders<BsonDocument>.Filter.Gte(new StringFieldDefinition<BsonDocument, BsonDateTime>("BDay"), new BsonDateTime(beginTime));