gpt4 book ai didi

javascript - 是否可以通过调整 CosmosDB 中的 TTL 值来触发删除触发器?

转载 作者:行者123 更新时间:2023-11-29 20:59:10 25 4
gpt4 key购买 nike

我已使用 Azure 门户中的脚本资源管理器创建了预删除触发器。下面的触发器是用 JavaScript 编写的:

function markReminderAsPastDue() {
var collection = getContext().getCollection();
var request = getContext().getRequest();
var docToCreate = request.getBody();
docToCreate["pastDue"] = true;
docToCreate["id"] = "";
var accepted = collection.createDocument(collection.getSelfLink(),
docToCreate,
function (err, documentCreated) {
if (err) throw new Error('Error' + err.message);
});
if (!accepted) throw new Error("Document creation not accepted");

}

我为关联集合中的每个文档设置了 TTL 值。因此,TTL 值不等于-1,一旦时间到期,文档就会自动删除。如果我手动删除文档,则会触发预删除触发器。但是,当由于 TTL 值而隐式删除文档时,不会触发触发器。我应该怎么做才能解决这个问题?是否可以使用 TTL 值触发触发器?

最佳答案

据我所知,Azure Cosmos DB 中没有任何类型的 TTL 回调机制。 TTL 强制执行只是一个后台线程,每秒查询已过期的文档,然后将其删除。

结合您的需求,我建议您在应用层中模仿 TTL 操作,您可以在其中执行任何额外的业务逻辑。

您可以在每个文档中设置更新时间属性,该属性会更新每次修改的更新时间。然后在你的应用层做一个轮询机制,每隔一段时间就迭代一下数据库,找出更新时间到期的数据,然后删除。

为了减轻您应用层的压力,您可以将删除数据的 Action 交给Cosmos DB Stored Procedure .

希望对您有帮助。

关于javascript - 是否可以通过调整 CosmosDB 中的 TTL 值来触发删除触发器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47550617/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com