首页 > 后端开发 > Golang > 如何使用 Golang 通过 Google App Engine 数据存储中的 ID 数组检索实体?

如何使用 Golang 通过 Google App Engine 数据存储中的 ID 数组检索实体?

Barbara Streisand
发布: 2024-10-25 17:32:44
原创
580 人浏览过

How to Retrieve Entities by an Array of IDs in Google App Engine Datastore using Golang?

使用 Golang 查询数据存储中具有 ID 数组的实体

在 Google App Engine 数据存储中,不直接支持执行“ IN”查询根据 ID 数组检索实体。但是,还有其他方法可以实现此功能。

范围查询(如果 ID 连续)

如果 ID 形成连续范围,您可以使用“>” (大于)和“

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

执行多个查询

对于不在连续范围内的ID,可以对数组中的每个ID执行单独的查询。这涉及为每个 ID 创建一个新的 Query 对象并按该 ID 进行过滤。

<code class="go">for _, id := range ids {
    q := datastore.NewQuery("Category").Filter("Id =", id)
    // ... perform query and retrieve entities
}</code>
登录后复制

GetMulti Function

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

<code class="go">var keys []*datastore.Key

for _, id := range ids {
    keys = append(keys, datastore.NewKey(c, "Category", "", id, nil))
}

categories := make([]Category, len(keys))
err := datastore.GetMulti(c, keys, categories)
if err != nil {
    // Handle error
}</code>
登录后复制

注意:

当使用 Filter() 方法指定多个过滤器,它们将通过 AND 运算连接起来。因此,您尝试使用 q.Filter("Id =", id) 按多个 ID 进行过滤可能会导致没有匹配的实体,除非所有 ID 都存在于同一实体中。

以上是如何使用 Golang 通过 Google App Engine 数据存储中的 ID 数组检索实体?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板