阅读量:0
MongoDB可以通过TTL(Time To Live)索引来自动删除过期数据。TTL索引是一种特殊类型的索引,它会根据字段的过期时间自动删除文档。
要设置自动删除过期数据,可以按照以下步骤进行操作:
- 创建一个包含过期时间的字段,例如
expireAt
字段,用于存储文档的过期时间。 - 创建一个TTL索引,将
expireAt
字段作为索引的键,并设置过期时间。
在上述示例中,db.collection.createIndex( { "expireAt": 1 }, { expireAfterSeconds: 0 } )
expireAfterSeconds
参数的值为0,表示过期时间为字段中存储的具体时间。 如果要设置相对时间,可以将expireAfterSeconds
参数设置为需要过期的秒数,例如设置为86400表示过期时间为24小时。 - 在插入文档时,将过期时间存储在
expireAt
字段中。
在上述示例中,将db.collection.insertOne( { "name": "John", "expireAt": new Date("2022-01-01") } )
expireAt
字段设置为2022年1月1日,表示文档将在该日期过期。 - MongoDB会自动删除过期的文档。
注意事项:
- MongoDB会在后台轮询TTL索引,并删除过期的文档,删除频率取决于MongoDB的内部进程,可能不是实时的。
- 过期时间存储在
expireAt
字段中的时间必须是一个UTC时间。