public class ScheduledEvent : Event
{
public DateTimeOffset StartDateTime { get; set; }
}
StartDateTime = 5272013 2:09:00 AM +00:00 代表05262013 07:09 PM PST。
MongoDB中记录的是什么。
> db.ScheduledEvent.find().toArray()
[
{
"_id" : BinData(3,"ZE2p31dh00qb6kglsgHgAA=="),
"Title" : "Today 26th at 7:09pm",
"Length" : "00:00:00",
"MoreInformation" : "http://1.com",
"Speakers" : [
{
"_id" : BinData(3,"ndzESsQGukmYGmMgKK0EqQ=="),
"Name" : "Mathias Brandewinder"
}
],
"Location" : {
"_id" : BinData(3,"AAAAAAAAAAAAAAAAAAAAAA=="),
"Name" : "Somwhere "
},
"Organizers" : [
{
"_id" : BinData(3,"AAAAAAAAAAAAAAAAAAAAAA=="),
"Name" : null
}
],
"CreatedOn" : [
NumberLong("635052144104050898"),
0
],
"StartDateTime" : [
NumberLong("635052173400000000"),
0
]
}
]
我意识到StartDateTime在MongoDB中被存储为Ticks.
var dateMarker = DateTimeOffset.UtcNow;
var nextDay = dateMarker.AddDays(1);
这个查询不工作。
var today = EventRepoistory.All().Where(z => z.StartDateTime >= dateMarker && z.StartDateTime < nextDay).OrderByDescending(z => z.StartDateTime).ToList();
我在Mongo C#驱动中添加了一个查询显示,显示如下查询。
{ "$query" : { "StartDateTime" : { "$gte" : [NumberLong("635052168609734070"), 0], "$lt" : [NumberLong("635053032609734070"), 0] } }, "$orderby" : { "StartDateTime" : -1 } }
下限 = 6350521 68609734070
服务器=6350521 73400000000
上限 = 6350530 32609734070
问题:为什么MongoDB查询不返回任何内容?为什么MongoDB查询没有返回任何内容?
db.ScheduledEvent.find({ "$query" : { "StartDateTime" : { "$gte" : [NumberLong("635052168609734070"), 0], "$lt" : [NumberLong("635053032609734070"), 0] }。}, "$orderby" : { "StartDateTime" : -1 }。})
研究了。
MongoDB和DateTimeOffset类型 但似乎LINQ提供者在做它应该做的事?
试过了。
db.ScheduledEvent.find({ "StartDateTime" : { "$gte" : [NumberLong("1"), 0] } } )
没有结果
这里也有类似的答案。MongoDB和DateTimeOffset类型 (如你在问题中所指出的)
我通过执行以下操作,让C#驱动工作起来。
var query = Query.GT("StartDateTime.0", startDate.Ticks);
var json = query.ToJson();
生成这个JSON。
{ "StartDateTime.0" : { "$gt" : NumberLong("635251617859913739") } }
上面的JSON是有效的。 根据链接的答案,原因是DateTimeOffset是一个数组。
当我使用LINQ时,我得到的JSON结果是不同的(如你所说)。
var query = from r in col.AsQueryable<MyObjectType>()
where r.StartDateTime>= startDate && r.StartDateTime< endDate
select r;
上面的LINQ查询产生了下面的JSON。
{ "StartDateTime" : { "$gte" : [NumberLong("635251617859913739"), 0], "$lt" : [NumberLong("635251635859913739"), 0] } }
我不确定C#驱动中的LINQ提供者是否需要固定来处理DateTimeOffset,但使用Query builder来指定DateTimeOffset数组的第一个元素(StartDateTime.0)是我得到这个结果的唯一方法。
在你的查询中使用以下语法。
{
"StartDateTime.0": {
"$gte": 635052168609734070
}
}
正如其他答案所说,问题的根本原因在于 DateTimeOffset
字段默认被序列化为数组(有ticks和offset)。
如果你能够在DAL层中本地化你的变化,并使用MongoDB特有的查询,那么dsandor提出的答案就可以正常工作。
然而,如果你的版本库暴露出了 IQueryable<ScheduledEvent>
和一些LINQ查询应用在服务层。
更通用的方法是改变如何在服务层中应用 DateTimeOffset
字段被序列化到MongoDB中,这样LINQ查询就能正常运行,而不需要定制MongoDB查询。
你可以很容易地改变序列化的 DateTimeOffset
字段有 BsonRepresentation(BsonType.String)
属性。
public class ScheduledEvent : Event
{
[BsonRepresentation(BsonType.String)]
public DateTimeOffset StartDateTime { get; set; }
}
在这种情况下 DateTimeOffset
字段以字符串形式保存到MongoDB中。2020-04-03T08:12:23+03:00
和LINQ查询正确工作。