现在我正在尝试确定哪个对我遇到的问题更有效。情况如下:问题陈述 我有一组对象,我想更新/插入到我的 Couchbase 数据库中。如果它们已经在数据库中,它们应该更新除一个以外的所有字段。如果它们不在数据库中,则应将它们简单地插入。我有一个工作的参数化 Merge 语句,它可以执行我想要的操作,它接受对象数组作为参数并相应地进行更新/插入。但我想知道,运行该单个查询是否更有效,或者循环遍历数组并为每个对象运行 Get() 键值操作是否更好,以查看它是否存在于数据库中,然后运行 insert() 函数?不幸的是,我对数组的大小没有一个很好的估计,但我所知道的是,如果这有帮助的话,这项工作不会经常运行。在此先感谢您的帮助!
1 回答
浮云间
TA贡献1829条经验 获得超4个赞
一般来说,如果您知道密钥,则使用 KV 服务效率更高,正如 vsr 指出的那样。
在这种特定情况下,您所做的事情只是稍微偏离了常规,所以然后回答“它更有效吗?” 可能取决于您正在使用的文档。
您可以尝试使用 KV 服务。测量并查看它是否优于 N1QL 查询。
第 1 步:使用子文档操作仅获取要保留其值的字段。如果找到该文档,请记住结果中的 CAS 值并转至步骤 3。否则转至第 2 步。
第 2 步:该文档不存在,因此尝试插入它。如果插入成功,你就完成了!否则,如果由于文档存在而插入失败(其他人在您之前插入了文档),请转到步骤 1。
第 3 步:获取您在第 1 步中检索到的现有字段值并将其合并到您的文档中。然后使用 CAS 值执行 REPLACE 操作。如果由于 CAS 不匹配而导致替换失败(其他人在您之前修改了文档),请转到步骤 1。
或者...如果您知道您的文档最多可以有 16 个顶级字段,您可以在单个子文档操作中完成整个更新。
- 1 回答
- 0 关注
- 164 浏览
添加回答
举报
0/150
提交
取消
