google-app-engine - 使用 golang 在 google app engine 数据存储上进行 "IN Array"查询

标签 google-app-engine go google-cloud-datastore

有没有办法在数据存储上使用 ids []int64 进行查询?我尝试了以下但无济于事。

  1. 错误输出

    q := datastore.NewQuery("Category").Filter("Id IN", ids)
    
  2. 给我获取数据存储中的所有类别

    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 "="

您可以做的是对数组中您要作为过滤依据的每个元素执行单独 查询。此外,如果元素在连续范围内,您可以替换 INid>=minid<=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

注意:

您的第二次尝试返回所有实体,因为您调用了 Filter()在您的查询上,但您不存储返回值,因此您最终执行的查询将根本没有过滤器。 Query.Filter()返回包含您刚刚指定的过滤器的派生查询,您必须使用返回的 Query正在进行中。所以应该是:

q = q.Filter("Id=", id)

但即使这样也不起作用:如果指定了多个过滤器,它们将处于逻辑 AND 连接中,因此它很可能会给你 0 个结果,因为我怀疑 Id 不存在类别。是一个列表,其中包含您要过滤的所有 ID。

关于google-app-engine - 使用 golang 在 google app engine 数据存储上进行 "IN Array"查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29202516/

相关文章:

python - 为每个用户创建唯一的个人资料页面 python

java - 我可以将子对象保留在父类的 @PrePersist 处理程序中吗? (客观化 3.1b1)

arrays - 如何使用映射分配结构类型值?

java - 使用 Java 且没有第 3 方框架(iOS 客户端)的谷歌应用引擎自定义身份验证 - 设计合理吗?

google-app-engine - 我可以通过对索引执行 0 次写入操作将项目保存到 Datastore 吗?

xml - 如何省略外部 XML 元素的名称

docker - "golang.org/x/net/ipv4"在 Mac 上工作,但在 Linux 上不工作

javascript - 尝试使用 Nodejs 8 加载 GoogleCloud 数据存储模块时出现 "Provided module can' t 加载错误

go - 无法在谷歌数据存储中存储字节数组

javascript - Node.js 谷歌云平台数据存储日期比较