首页  >  文章  >  后端开发  >  如何使用 Go 在 Google App Engine 数据存储中使用整数切片执行“IN”查询?

如何使用 Go 在 Google App Engine 数据存储中使用整数切片执行“IN”查询?

DDD
DDD原创
2024-10-28 04:49:30513浏览

How to Perform

使用 Go 在 Google App Engine 数据存储区中进行 IN 数组查询

在 App Engine 数据存储区中,不直接支持使用整数切片执行“IN”查询过滤功能。但是,可以采用多种方法来实现类似的功能。

方法 1:多条件查询

一种选择是为整数切片中的每个元素创建单独的查询。这种方式适合元素数量比较少的情况。

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

方式二:连续范围的范围查询

如果整数切片中的元素表示连续范围,则可以使用范围运算符(>= 和

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

方法 3:GetMulti 进行 Key IN 查询

如果被过滤的属性是实体键,您可以使用 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)</code>

注意:

第二种方法使用多个过滤器调用无法正常工作。以这种方式应用多个过滤器会产生逻辑 AND 连接,并且没有实体可能会同时满足所有条件。

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

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