在 App Engine 数据存储区中,不直接支持使用整数切片执行“IN”查询过滤功能。但是,可以采用多种方法来实现类似的功能。
一种选择是为整数切片中的每个元素创建单独的查询。这种方式适合元素数量比较少的情况。
<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>
如果被过滤的属性是实体键,您可以使用 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中文网其他相关文章!