dsaff82024 2016-01-11 17:56
浏览 50
已采纳

Google App引擎:Golang datastore.GetAll()无法正常工作

Once a week a cron job calls the following function in one of my app engine projects:

func cleanMealsFromDatabase(context appengine.Context) error {
    query := datastore.NewQuery("Essen").Limit(1000).KeysOnly()
    keys, err := query.GetAll(context, nil)
    if err != nil {
        return err
    }
    return datastore.DeleteMulti(context, keys)
}

I'm trying to batch delete a bunch of datastore entities. The function gets called correctly, but

query.GetAll(context, nil)

seems to always return an error. Am I doing something wrong?

  • 写回答

1条回答 默认 最新

  • dsykx64220 2016-01-12 08:47
    关注

    Okay, I now know what went wrong. When I finally figured out how to log an error in app engine, it said:

    API error 1 (datastore_v3: BAD_REQUEST): cannot write more than 500 entities in a single call
    

    So all I had to do, was to change the Limit parameter from 1000 to 500 like this:

    query := datastore.NewQuery("Essen").Limit(500).KeysOnly()
    

    Now it works like intended.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 nslt的可用模型,或者其他可以进行推理的现有模型
  • ¥15 arduino上连sim900a实现连接mqtt服务器
  • ¥15 vncviewer7.0安装后如何正确注册License许可证,激活使用
  • ¥15 phython如何实现以下功能?查找同一用户名的消费金额合并2
  • ¥66 关于人体营养与饮食规划的线性规划模型
  • ¥15 基于深度学习的快递面单识别系统
  • ¥15 Multisim仿真设计地铁到站提醒电路
  • ¥15 怎么用一个500W电源给5台60W的电脑供电
  • ¥15 请推荐一个轻量级规则引擎,配合流程引擎使用,规则引擎负责判断出符合规则的流程引擎模板id
  • ¥15 Excel表只有年月怎么计算年龄