gpt4 book ai didi

go - N1QL 键值操作与查询

转载 作者:行者123 更新时间:2023-12-01 20:18:44 25 4
gpt4 key购买 nike

现在我正在尝试确定哪个对我遇到的问题更有效。这是情况:
问题说明
我有一组要更新/插入到我的 Couchbase 数据库中的对象。如果它们已经在数据库中,则它们应该更新除一个字段之外的所有字段。如果它们不在数据库中,它们应该简单地插入。我有一个工作参数化的 Merge 语句,它可以执行我想要的操作,它接受对象数组作为参数并相应地进行更新/插入。但我想知道,运行该单个查询是否更有效,还是更好地遍历数组并为每个对象运行 Get() 键值操作,以查看它是否存在于数据库中,然后运行 ​​insert()功能?
不幸的是,我对数组的大小没有很好的估计,但我所知道的是,如果这有帮助的话,这项工作不会经常运行。在此先感谢您的帮助!

最佳答案

一般而言,如 vsr 所指出的,如果您知道 key ,则使用 KV 服务会更有效率。
在这种特定情况下,您正在做一些稍微偏离常规的事情,因此请回答“它更有效吗?”可能取决于您正在处理的文档。
这是您可以尝试使用 KV 服务的方法。测量并查看它是否优于 N1QL 查询。
步骤 1:使用子文档操作仅获取要保留其值的字段。如果找到文档,请记住结果中的 CAS 值并转到 第 3 步 .否则转至 第 2 步 .
STEP 2:文档不存在,尝试插入。如果插入成功,你就完成了!否则,如果由于文档存在而导致插入失败(其他人在您之前插入了文档),请转到 第 1 步 .
第 3 步:将您在第 1 步中检索到的现有字段值合并到您的文档中。然后使用 CAS 值执行 REPLACE 操作。如果由于 CAS 不匹配而导致替换失败(其他人在您之前修改了文档)转到 第 1 步 .

或者...如果您知道您的文档最多可以有 16 个顶级字段,您可以在单个子文档操作中完成整个更新。

关于go - N1QL 键值操作与查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63604725/

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