首页  >  文章  >  后端开发  >  如何使用 Go 在 Google App Engine 数据存储中按 ID 检索实体:“IN Array”查询的替代方案?

如何使用 Go 在 Google App Engine 数据存储中按 ID 检索实体:“IN Array”查询的替代方案?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-10-26 12:50:02359浏览

How to Retrieve Entities by IDs in Google App Engine Datastore with Go: Alternatives to

使用 Go 在 Google App Engine 数据存储区中按 ID 检索实体

使用 Google App Engine 数据存储区时,执行高效查询至关重要检索特定实体。其中一个查询是“IN Array”查询,您可以在其中根据 ID 数组过滤实体。

执行“IN Array”查询的挑战

In Go,数据存储 API 不直接支持“IN”数组过滤器。尝试使用 datastore.NewQuery("Category").Filter("Id IN", ids) 将导致错误。

替代方法

While "IN “过滤器不能直接使用,有其他方法可以达到相同的结果:

1.迭代查询

您可以对数组中的每个 ID 执行单独的查询。例如:

<code class="go">ids := []int64{1,2,3,4}
for _, id := range ids {
    q := datastore.NewQuery("Category").Filter("Id =", id)
}</code>

2。范围查询

如果ID在连续范围内,则可以使用范围查询而不是“IN”过滤器。例如:

<code class="go">ids := []int64{1,2,3,4}
q := datastore.NewQuery("Category").Filter("Id>=", 1).Filter("Id<=", 4)</code>

3。 GetMulti 函数

如果您要过滤的属性是实体键本身,则可以使用 datastore.GetMulti() 函数检索由键数组指定的实体列表。例如:

<code class="go">keys := make([]*datastore.Key, len(ids))
for i, id := range ids {
    keys[i] = datastore.NewKey(c, "Category", "", id, nil)
}

categories := make([]Category, len(keys))
err := datastore.GetMulti(c, keys, categories)</code>

注意:

对于大型数组,迭代查询可能效率较低。范围查询适用于连续范围,但不支持间隙。 GetMulti 针对通过键检索实体进行了优化。

以上是如何使用 Go 在 Google App Engine 数据存储中按 ID 检索实体:“IN Array”查询的替代方案?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn