使用 golang 在 google 应用引擎数据存储上执行 "IN Array" 查询
Doing a "IN Array" query on google app engine datastore with golang
有没有办法在数据存储上使用 ids []int64
进行查询?我尝试了以下但无济于事。
出错
q := datastore.NewQuery("Category").Filter("Id IN", ids)
让我获取数据存储区中的所有类别
for _, id := range ids {
q.Filter("Id =", id)
}
在icza的回答后
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
}
通常 "IN"
数据存储不支持过滤器。 Query.Filter()
的文档列出了允许的运算符:
">", "<", ">=", "<=", or "="
您可以对数组中的每个元素执行单独 查询作为过滤依据。此外,如果元素在连续范围内,您可以将 IN
替换为 id>=min
和 id<=max
。例如:
ids := []int64{1,2,3,4}
q := datastore.NewQuery("Category").Filter("Id>=", 1).Filter("Id<=", 4)
另请注意,虽然通常不支持 IN
,但如果 属性 是实体键本身,您可以使用datastore.GetMulti()
函数:
func GetMulti(c appengine.Context, key []*Key, dst interface{}) error
注:
你第二次尝试 return 所有实体,因为你在查询中调用 Filter()
,但你没有存储 return 值,所以你最终执行的查询将根本没有过滤器。 Query.Filter()
returns 是一个派生查询,其中包含您刚刚指定的过滤器,您必须使用 returned Query
进行中。所以应该是:
q = q.Filter("Id=", id)
但即使这样也不起作用:如果指定了多个过滤器,它们将处于逻辑 AND 连接中,因此很可能会给你 0 个结果,因为我怀疑 Id
所在的位置不存在类别一个列表,其中包含您要过滤的所有 ID。
有没有办法在数据存储上使用 ids []int64
进行查询?我尝试了以下但无济于事。
出错
q := datastore.NewQuery("Category").Filter("Id IN", ids)
让我获取数据存储区中的所有类别
for _, id := range ids { q.Filter("Id =", id) }
在icza的回答后
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
}
通常 "IN"
数据存储不支持过滤器。 Query.Filter()
的文档列出了允许的运算符:
">", "<", ">=", "<=", or "="
您可以对数组中的每个元素执行单独 查询作为过滤依据。此外,如果元素在连续范围内,您可以将 IN
替换为 id>=min
和 id<=max
。例如:
ids := []int64{1,2,3,4}
q := datastore.NewQuery("Category").Filter("Id>=", 1).Filter("Id<=", 4)
另请注意,虽然通常不支持 IN
,但如果 属性 是实体键本身,您可以使用datastore.GetMulti()
函数:
func GetMulti(c appengine.Context, key []*Key, dst interface{}) error
注:
你第二次尝试 return 所有实体,因为你在查询中调用 Filter()
,但你没有存储 return 值,所以你最终执行的查询将根本没有过滤器。 Query.Filter()
returns 是一个派生查询,其中包含您刚刚指定的过滤器,您必须使用 returned Query
进行中。所以应该是:
q = q.Filter("Id=", id)
但即使这样也不起作用:如果指定了多个过滤器,它们将处于逻辑 AND 连接中,因此很可能会给你 0 个结果,因为我怀疑 Id
所在的位置不存在类别一个列表,其中包含您要过滤的所有 ID。