c# - 如何为存储为数组 [ticks,offset] 的 DatetimeOffset 创建 MongoDB TTL 索引?

标签 c# mongodb mongodb-.net-driver

我正在尝试在包含具有 DateTimeOffset 的文档的集合上创建 MongoDB TTL 索引。但是日期作为一个刻度数组和偏移量 [ticks, offset] 保存。 例如:

TimeStamp:Array [
    0:636803424000000000, 
    1:-360]

我的模型如下所示:

public class Log
{
    ....
    DateTimeOffset? TimeStamp{get; set;}
}

我正在使用 MongoDb.Driver v2.7.2,我一直在尝试以这种方式创建索引

....
var indexKeysDefinition = Builders<Log>.IndexKeys.Descending(l => l.TimeStamp);
var indexOptions = new CreateIndexOptions 
{ 
    ExpireAfter = TimeSpan..FromTicks(TimeSpan.TicksPerMinute), 
    Name = "LogsTimeStamPIndex", 
    Background = true 
};
var model = new CreateIndexModel<Log>(indexKeysDefinition, indexOptions);
await _database.GetCollection<Log>("Log").Indexes.CreateOneAsync(model);
....

这是在创建索引,但文档不会在 1 分钟后过期。如何为以这种方式存储的 DateTimeOffset 创建 TTL?或者我在这里错过了什么?

最佳答案

我想这会对将来的人有所帮助。 我的团队实际上联系了 MognoDb 工程师,他们通知我们日期必须是用于 TTL 索引的 ISO 日期。显然 [tick, offset] 的格式不正确。再次感谢 Adam Harrison 早些时候指出这一点。

关于c# - 如何为存储为数组 [ticks,offset] 的 DatetimeOffset 创建 MongoDB TTL 索引?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53855862/

相关文章:

c# - 如何安排调试?

c# - 查询数据库中的每条记录比使用 LINQ 更快

C# 如何使用 SharpSVN 正确反向合并

c# - System.Web.Services.Protocols.SoapHttpClientProtocol 使用什么版本的 SSL/TLS?

mongodb - 如何聚合嵌套文档?

c# - MongoDb 和自引用对象

mongodb - 在 MongoDB C# 驱动程序中获取 DBRef 的命名空间引用

javascript - 将数据插入 Mongoose 模型数组?

MongoDB固定大小数组实现

mongodb - C# MongoDB - 绑定(bind)对象属性,插入时 _id 为空