在Golang中使用Google数据存储区中的任意键数组进行查询

时间:2015-03-27 16:42:55

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

此问题的延续:

  

Doing a "IN Array" query on google app engine datastore with golang

现在,我正在遵循上一个问题中有关使用一组键/ ID ids []int64进行查询的建议。这些ID实际上可能存在也可能不存在(它们已被删除,但其他实例上的引用尚未删除)。

我尝试获取这些实例的方法如下:

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
}

for i := 0; i < len(categories); i++ {
    categories[i].Id = keys[i].IntID()
}

然而,它错误地抛弃了我:

datastore: no such entity
另一方面,我可以单独抓住每一个,但有没有更有效的方法来解决这个问题?

1 个答案:

答案 0 :(得分:2)

您需要键入断言错误到appengine.MultiError。这样,您就可以访问单个实体的错误。

if me, ok := err.(appengine.MultiError); ok {
    for i, e := range me {
        // e != nil if entity i failed
    }
} else {
   // something else went wrong (timeout, etc).
}

请参阅MultiError here

的文档