我已在 Azure Cosmos DB 容器中为字段 UniqueName
定义了 UniqueKey 策略。
下面的函数正在计时器上调用。
我正在尝试使用 Azure Functions 绑定(bind)更新 Azure Cosmos DB 中的文档,如下所示:
public async Task ManageItems([ActivityTrigger] string records,
[CosmosDB(
databaseName: "mydatabase",
collectionName: "items",
ConnectionStringSetting = "CosmosDbConnectionString")] DocumentClient client,
ILogger log)
{
var collectionUri = UriFactory.CreateDocumentCollectionUri("mydatabase", "items");
foreach (var record in records)
{
log.LogDebug($"Upserting itemNumber={record.UniqueName}");
await client.UpsertDocumentAsync(collectionUri, record);
}
}
在空白“items”容器中首次执行期间,每条记录的更新插入效果非常好,将每条记录作为特定文档插入。
但是,当对与第一次执行相同的数据进行测试时,但现在期望“更新”而不是“插入”尝试,我得到一个异常:
UpsertDocumentAsync
之后违反唯一索引约束方法运行。
我在这里缺少什么?
据我了解,Upsert 是更新或插入,具体取决于对象是否存在(通过其唯一标识符)。
检查方法中的传出对象唯一 ID 是否与现有文档唯一 ID 匹配应该在 Cosmos DB 容器级别进行。
我期望发生的是调用注意到具有该唯一 ID 的文档已经存在,并且它执行更新,而不是抛出异常。如果该方法仅插入,我希望它会抛出异常。
最佳答案
此问题已通过在“记录”来源的类中指定显式“id”
字段得到解决。
“id”
已设置为我想用作唯一值的唯一“recordNumber”。
为了更好地衡量,我在 UpsertDocumentAsync 方法中将disableAutomaticIdGeneration 设置为 true
UpsertDocumentAsync(collectionUri, record, disableAutomaticIdGeneration:true);
不再有唯一索引违规,也没有重复。
值得注意的是,该解决方案与此类似:How can I insert/update data in CosmosDB in an Azure function
关于Azure Cosmos DB : Unique index constraint violation using UpsertDocumentAsync,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70162287/