登录
首页 >  Golang >  Go问答

设置 gorm 查询的超时时长

来源:stackoverflow

时间:2024-03-09 18:15:18 406浏览 收藏

大家好,今天本人给大家带来文章《设置 gorm 查询的超时时长》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

有没有办法在运行长查询时将 gorm 设置为在可配置的时间段后超时?我正在使用mssql。我查阅了文档,还没有找到方法。


解决方案


这段代码似乎对我有用并且非常干净。我猜只是使用交易。

//gorm query below
query = query.where(whereclause)
//set up timeout
ctx, cancel := context.withtimeout(context.background(), 10*time.second)
defer cancel()
var x sql.txoptions
db := query.begintx(ctx, &x)
defer db.commit()
// execute the query
if err := db.find(*results).error; err != nil {
    return err
}

通过使用 *gorm.db 中的 withcontext,您可以将 timeout context 传递给 gorm

ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel()

var products []Product
db.WithContext(ctx).Find(&products)

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>