我在 BigQuery 中有 1000000 条记录。从数据库中获取数据并使用 goLang 进行处理的最佳方法是什么?如果无限制地获取所有数据,我会遇到超时问题。我已经将限制增加到 5 分钟,但它需要超过 5 分钟。我想做一些流式调用或分页实现,但我不知道在 golang 中我该怎么做。
var FetchCustomerRecords = func(req *http.Request) *bigquery.RowIterator {
ctx := appengine.NewContext(req)
ctxWithDeadline, _ := context.WithTimeout(ctx, 5*time.Minute)
log.Infof(ctx, "Fetch Customer records from BigQuery")
client, err := bigquery.NewClient(ctxWithDeadline, "ddddd-crm")
q := client.Query(
"SELECT * FROM Something")
q.Location = "US"
job, err := q.Run(ctx)
if err != nil {
log.Infof(ctx, "%v", err)
}
status, err := job.Wait(ctx)
if err != nil {
log.Infof(ctx, "%v", err)
}
if err := status.Err(); err != nil {
log.Infof(ctx, "%v", err)
}
it, err := job.Read(ctx)
if err != nil {
log.Infof(ctx, "%v", err)
}
return it
}
料青山看我应如是
holdtom
相关分类