首页 >后端开发 >Golang >如何使用 Go 在 Google App Engine 数据存储中执行'IN Array”查询?

如何使用 Go 在 Google App Engine 数据存储中执行'IN Array”查询?

Patricia Arquette
Patricia Arquette原创
2024-10-26 02:52:021079浏览

How to Execute

使用 Go 在 Google App Engine 数据存储区中执行“IN Array”查询

执行“IN Array”查询,其中检查数据存储区中特定属性的多个值,由于缺乏对此类查询的本机支持,因此需要在 Go 中采用不同的方法。

1.顺序查询

一种选择是对数组中要作为筛选依据的每个元素执行单独的查询。例如:

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

2。连续范围(仅适用于连续数组)

如果数组中的元素形成连续范围,则可以使用 >= 和

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

3。 datastore.GetMulti()

如果要过滤的属性是实体键本身,您可以使用 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 {
    return nil, err
}</code>

注意:请记住,使用 AND 的复合过滤器可能会返回意外结果,因为多个过滤器将按逻辑应用。

以上是如何使用 Go 在 Google App Engine 数据存储中执行'IN Array”查询?的详细内容。更多信息请关注PHP中文网其他相关文章!

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