我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何在很短的间隔/同时进行多个查询

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何在很短的间隔/同时进行多个查询

今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《如何在很短的间隔/同时进行多个查询》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!

问题内容

嘿,我收到一条错误消息:来自 pgx 的 conn busy

我不知道如何解决这个问题。这是我的功能:

func (r *proverbRepo) SelectPendingProverbs(table string) (proverbs []domain.Proverb, err error) {
    query := fmt.Sprintf("SELECT id, proverb literal FROM %s", table)
    rows, err := r.Db.Query(context.Background(), query)
    defer rows.Close()

    if err != nil {
        return
    }

    for rows.Next() {
        var prov domain.Proverb
        if err = rows.Scan(&prov.ID, &prov.Literal); err != nil {
            return
        }
        proverbs = append(proverbs, prov)
    }
    return
}

r.dbpgx.connect(context.background(), os.getenv("psql_url"))

我在很短的时间内从两个单独的前端请求获取两个不同的表。

第一个请求通过,另一个请求返回 conn busy 错误消息。

我真的不知道要寻找什么,有人可以帮助我吗?


解决方案


pgx.connect() 返回一个不能同时使用的 pgx.conn。这是该类型的 godocs 的状态:

conn 是 postgresql 连接句柄。并发使用并不安全。使用连接池来管理多个 goroutine 对多个数据库连接的访问​​。

因此,如果您将 pgx.connect() 替换为 github.com/jackc/pgx/pgxpool 中的 pgxpool.connect() ,应该没问题。

pgx 返回的 r.db 。 connect(context.background(), os.getenv("psql_url")) 如果类型为 *pgx.conn 并且表示非并发安全的单个连接。通常,您希望使用连接池来为您处理并发并允许重用打开的连接。 要使用连接池,请将 import github.com/jackc/pgx/v4 替换为 github.com/jackc/pgx/v4/pgxpool 并使用 pgxpool.connect() 而不是 pgx.connect() 连接,并且 api 将是一样的:

r.pool := pgxpool.connect(context.background(), os.getenv("psql_url"))
r.pool.query(context.background(), query)
...

如果在任何给定点您需要使用单个连接来访问某些较低级别的功能,您可以安全地获取并发安全连接,如下所示:

conn, err := r.Pool.Acquire(context.Background())
if err != nil {
    fmt.Fprintln(os.Stderr, "Error acquiring connection:", err)
    os.Exit(1)
}
defer conn.Release()
...

好了,本文到此结束,带大家了解了《如何在很短的间隔/同时进行多个查询》,希望本文对你有所帮助!关注编程网公众号,给大家分享更多Golang知识!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何在很短的间隔/同时进行多个查询

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何在很短的间隔/同时进行多个查询

今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《如何在很短的间隔/同时进行多个查询》,主要内容是讲解等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!问题内容嘿
如何在很短的间隔/同时进行多个查询
2024-04-05

linux如何查看某个进程的运行时间

小编给大家分享一下linux如何查看某个进程的运行时间,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!查看某个进程的运行时间可能,大部分同学只会使用 ps aux,其实可以通过 -o 参数,指定只显示具体的某个字段,会得到更
2023-06-27

如何在 Linux 中查找一个命令或进程的执行时间

在类 Unix 系统中,你可能知道一个命令或进程开始执行的时间,以及一个进程运行了多久。 但是,你如何知道这个命令或进程何时结束或者它完成运行所花费的总时长呢? 在类 Unix 系统中,这是非常容易的! 有一个专门为此设计的程序名叫 GNU
2022-06-04

如何实现在分组的情况下,以另一个时间字段查询出结果?

假如有这样一张表:脚本如下:DROP TABLE IF EXISTS `jl_site_operation`;CREATE TABLE `jl_site_operation` ( `id` int(11) NOT NULL AUTO_INCREMENT,
2020-04-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录