此问题的延续:
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
另一方面,我可以单独抓住每一个,但有没有更有效的方法来解决这个问题?
答案 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
的文档