为什么我的 Azure Cosmos DB SQL API 容器拒绝具有相同分区键值的多个项目?
Why does my Azure Cosmos DB SQL API Container Refuse Multiple Items With Same Partition Key Value?
在 Azure Cosmos DB (SQL API) 中,我创建了一个容器,其“分区键”设置为 /part_key
,我现在正在尝试创建和编辑数据在数据资源管理器中。
我创建了一个如下所示的项目:
{
"id": "test_id",
"value": "val000",
"magicNumber": 32,
"part_key": "asdf"
}
我现在正在尝试创建如下所示的项目:
{
"id": "frank",
"value": "val001",
"magicNumber": 33,
"part_key": "asdf"
}
根据文档,我认为分区键中的每个项目都需要一个不同的 id
,这对我来说意味着多个项目实际上可以共享一个分区键,这很有意义。
但是,当我尝试保存第二个项目时出现错误:
{"code":409,"body":{"code":"Conflict","message":"Entity with the specified id already exists in the system...
我看到如果我将 part_key
的值更改为其他值(比如 asdf2
),那么我可以保存这个新项目。
要么我对这个功能的期望是错误的,要么我做错了。这里有什么问题?
你的理解是正确的,如果你试图用一个新的文档代替一个与现有文档的 ID 相同的文档,就会发生这种情况。这是不允许的,所以操作失败。
在插入修改后的副本之前,您需要为其分配一个新的id。我测试了这个场景,它看起来不错。可以尝试创建一个新文档并检查
在 Azure Cosmos DB (SQL API) 中,我创建了一个容器,其“分区键”设置为 /part_key
,我现在正在尝试创建和编辑数据在数据资源管理器中。
我创建了一个如下所示的项目:
{
"id": "test_id",
"value": "val000",
"magicNumber": 32,
"part_key": "asdf"
}
我现在正在尝试创建如下所示的项目:
{
"id": "frank",
"value": "val001",
"magicNumber": 33,
"part_key": "asdf"
}
根据文档,我认为分区键中的每个项目都需要一个不同的 id
,这对我来说意味着多个项目实际上可以共享一个分区键,这很有意义。
但是,当我尝试保存第二个项目时出现错误:
{"code":409,"body":{"code":"Conflict","message":"Entity with the specified id already exists in the system...
我看到如果我将 part_key
的值更改为其他值(比如 asdf2
),那么我可以保存这个新项目。
要么我对这个功能的期望是错误的,要么我做错了。这里有什么问题?
你的理解是正确的,如果你试图用一个新的文档代替一个与现有文档的 ID 相同的文档,就会发生这种情况。这是不允许的,所以操作失败。
在插入修改后的副本之前,您需要为其分配一个新的id。我测试了这个场景,它看起来不错。可以尝试创建一个新文档并检查