N1QL 键值操作与查询
N1QL Key-value operations vs. Queries
现在我正在尝试确定哪个更有效地解决我遇到的问题。情况是这样的:
问题陈述
我有一组对象,我想 update/insert 到我的 Couchbase 数据库中。如果他们已经在数据库中,他们应该更新除一个之外的所有字段。如果它们不在数据库中,则应将它们简单地插入。我有一个工作参数化的 Merge 语句可以执行我想要的操作,它接受对象数组作为参数并相应地执行 update/inserts。但我想知道, 是 运行 单个查询更有效,还是遍历数组并为每个对象 运行 一个 Get() 键值操作更好为每个对象查看它是否存在于数据库中,然后 运行 一个 insert() 函数?
不幸的是,我对数组的大小没有很好的估计,但我所知道的是这项工作不会 运行 非常频繁,如果有帮助的话。预先感谢您的帮助!
一般来说,如果你知道密钥,使用 KV 服务会更有效率,正如 vsr 所指出的。
在这种特定情况下,您所做的事情只是稍微偏离了常规,那么请回答“它更有效吗?”可能取决于您使用的文档。
您可以尝试使用 KV 服务。测量并查看它是否 out-performs N1QL 查询。
第 1 步:使用 sub-document 操作仅获取要保留其值的字段。如果找到文档,请记住结果中的 CAS 值并转到 步骤 3。否则转到 步骤 2。
第 2 步:文档不存在,请尝试插入。如果插入成功,你就完成了!否则,如果由于文档存在而导致插入失败(其他人在您之前插入了该文档),请转到 步骤 1。
第 3 步:获取您在第 1 步中检索到的现有字段值并将其合并到您的文档中。然后使用 CAS 值执行 REPLACE 操作。如果由于 CAS 不匹配导致替换失败(其他人在您之前修改了文档)转到 步骤 1。
或者...如果您知道您的文档最多可以有 16 个 top-level 字段,您可以在单个子文档操作中完成整个更新。
现在我正在尝试确定哪个更有效地解决我遇到的问题。情况是这样的:
问题陈述 我有一组对象,我想 update/insert 到我的 Couchbase 数据库中。如果他们已经在数据库中,他们应该更新除一个之外的所有字段。如果它们不在数据库中,则应将它们简单地插入。我有一个工作参数化的 Merge 语句可以执行我想要的操作,它接受对象数组作为参数并相应地执行 update/inserts。但我想知道, 是 运行 单个查询更有效,还是遍历数组并为每个对象 运行 一个 Get() 键值操作更好为每个对象查看它是否存在于数据库中,然后 运行 一个 insert() 函数?
不幸的是,我对数组的大小没有很好的估计,但我所知道的是这项工作不会 运行 非常频繁,如果有帮助的话。预先感谢您的帮助!
一般来说,如果你知道密钥,使用 KV 服务会更有效率,正如 vsr 所指出的。
在这种特定情况下,您所做的事情只是稍微偏离了常规,那么请回答“它更有效吗?”可能取决于您使用的文档。
您可以尝试使用 KV 服务。测量并查看它是否 out-performs N1QL 查询。
第 1 步:使用 sub-document 操作仅获取要保留其值的字段。如果找到文档,请记住结果中的 CAS 值并转到 步骤 3。否则转到 步骤 2。
第 2 步:文档不存在,请尝试插入。如果插入成功,你就完成了!否则,如果由于文档存在而导致插入失败(其他人在您之前插入了该文档),请转到 步骤 1。
第 3 步:获取您在第 1 步中检索到的现有字段值并将其合并到您的文档中。然后使用 CAS 值执行 REPLACE 操作。如果由于 CAS 不匹配导致替换失败(其他人在您之前修改了文档)转到 步骤 1。
或者...如果您知道您的文档最多可以有 16 个 top-level 字段,您可以在单个子文档操作中完成整个更新。