0

我正在尝试使用我的 graphql/nodejs 代码删除和更新 cosmosDB 中的记录,但出现错误 - “系统中不存在具有指定 ID 的实体”。这是我的代码

deleteRecord: async (root, id) => {
  const { resource: result } = await container.item(id.id, key).delete();
  console.log(`Deleted item with id: ${id}`);
},

不知何故,下面的代码无法找到记录,甚至“container.item(id.id, key).read()”也不起作用。

await container.item(id.id, key)

但是,如果我尝试使用查询规范查找记录,它可以工作

await container.items.query('SELECT * from c where c.id = "'+id+'"' ).fetchNext()

仅供参考-我能够获取所有记录并创建新项目,因此与数据库的连接和读/写不是问题。

还能是什么?与此相关的任何指针都会有所帮助。

提前致谢。

4

1 回答 1

2

看来您将错误的密钥传递给item(id,key). 根据本文档的注释:

在“更新”和“删除”方法中,必须通过调用 container.item() 从数据库中选择项目。传入的两个参数是item的id和item的partition key。在这种情况下,分区键是“类别”字段的值。

因此,您需要传递分区键的值,而不是分区键路径。例如,如果您有如下文件,并且您的分区键是 '/category',则需要使用此代码await container.item("xxxxxx", "movie")

{
    "id":"xxxxxx",
    "category":"movie"
}
于 2020-11-02T02:47:55.673 回答