RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 965496
Accepted
Geo
Geo
Asked:2020-04-04 20:39:12 +0000 UTC2020-04-04 20:39:12 +0000 UTC 2020-04-04 20:39:12 +0000 UTC

与 MySQL 的连接

  • 772

我在go中写了一个函数,提升与数据库的连接,取出数据并关闭连接,但是函数完成后,连接仍然存在,直到我暂停程序

func selectSites() (sites siteList, list string) {

    connectSetting := fmt.Sprintf(
        "%s:%s@tcp(%s:%s)/%s?charset=utf8&parseTime=True",
        config.AppConfig.DB.User,
        config.AppConfig.DB.Pass,
        config.AppConfig.DB.Host,
        strconv.Itoa(config.AppConfig.DB.Port),
        config.AppConfig.DB.Name,
    )

    db, err := sql.Open("mysql", connectSetting)
    defer db.Close()


    rows, err := db.Query(config.AppConfig.SQL.SelectList)
    defer rows.Close()
    if err == nil {
        for rows.Next() {
            err := rows.Scan(&list)
            if err != nil {
                config.InLog("selectSites list parse err %s", err.Error())
                continue
            }
        }

    } else {
        config.InLog("selectSites list err %s", err.Error())
    }

    return
}

程序启动前数据库中的进程数 在此处输入图像描述

函数完成后数据库中的进程数 在此处输入图像描述

在不停止程序的情况下杀死第三个进程需要做什么

mysql
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Ivan Black
    2020-04-05T02:50:58Z2020-04-05T02:50:58Z

    首先,在 Go 中,习惯上将错误放在if-blocks 中,从而在没有此类错误时将错误处理代码与代码分开。其次,没有开库检查,万一出错db.Query()又会defer db.Close()引起panic。第三,rows.Err()未检查database/sql#Rows。

    好吧,实际上,数据库使用连接池并在之后重用这些连接。在这种情况下,创建新连接只会从池中获取连接,而不是创建新连接。例如,如果您的应用程序使用 100 个连接,那么它们很可能都在池中 - 永久打开以便以后可以使用。出于这些目的,驱动程序不会关闭您的连接。

    注意

    • SetConnMaxLifetime
    • SetMaxIdleConns
    • SetMaxOpenConns

    其中分别是连接生命周期、最大挂起连接数和最大打开连接数。所有这些设置都与连接池有关。

    func selectSites() (sites siteList, list string) {
    
        connectSetting := fmt.Sprintf(
            "%s:%s@tcp(%s:%s)/%s?charset=utf8&parseTime=True",
            config.AppConfig.DB.User,
            config.AppConfig.DB.Pass,
            config.AppConfig.DB.Host,
            strconv.Itoa(config.AppConfig.DB.Port),
            config.AppConfig.DB.Name,
        )
    
        db, err := sql.Open("mysql", connectSetting)
        if err != nil {
            config.InLog("opening DB %v", err)
            return
        }
        defer db.Close()
    
        rows, err := db.Query(config.AppConfig.SQL.SelectList)
        defer rows.Close()
        if err != nil {
            config.InLog("selectSites list err %v", err)
            return
        }
    
        for rows.Next() {
            err := rows.Scan(&list)
            if err != nil {
                config.InLog("selectSites list parse err %v", err)
                return
            }
        }
    
        if err := rows.Err(); err != nil {
            config.InLog("selectSites list parse err %v", err)
            return
        }
    
        return
    }
    

    好吧,其余的取决于使用哪个 MySQL 驱动程序。并且在此应用程序中是否存在与同一数据库的任何其他连接。

    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    根据浏览器窗口的大小调整背景图案的大小

    • 2 个回答
  • Marko Smith

    理解for循环的执行逻辑

    • 1 个回答
  • Marko Smith

    复制动态数组时出错(C++)

    • 1 个回答
  • Marko Smith

    Or and If,elif,else 构造[重复]

    • 1 个回答
  • Marko Smith

    如何构建支持 x64 的 APK

    • 1 个回答
  • Marko Smith

    如何使按钮的输入宽度?

    • 2 个回答
  • Marko Smith

    如何显示对象变量的名称?

    • 3 个回答
  • Marko Smith

    如何循环一个函数?

    • 1 个回答
  • Marko Smith

    LOWORD 宏有什么作用?

    • 2 个回答
  • Marko Smith

    从字符串的开头删除直到并包括一个字符

    • 2 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5