一文理清database/sql包的使用场景和宕机查询流程

2024-05-25 19:52

本文主要是介绍一文理清database/sql包的使用场景和宕机查询流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一文理清database/sql包你可能遇到的问题

    • 那么database/sql包实现了什么功能呢?
      • 建立数据库连接
      • 检测连接是否能ping通
      • 通过连接进行具体的sql查询
      • 查询完将连接进行关闭
      • 当数据库宕掉重启后再次查询
    • database/sql包创建的db连接 对于数据库宕掉后重启是否仍然有效?


当你点开这篇文章的时候你应该是想用go来与数据库进行交互的咯,那么正常流程下,你会涉及到建立数据库连接、检测连接是否能ping通、通过连接进行具体的sql查询,查询完将连接进行关闭,当数据库宕掉重启后再次查询等等。下面对于这些实现都会有介绍。

那么database/sql包实现了什么功能呢?

我们来看一下官方的答案。

Go语言中的database/sql包提供了一套与数据库进行交互的统一编程接口。它的主要功能和特性可以总结为以下几点:

  1. 统一的编程接口database/sql包通过提供一组统一的API,如Prepare(), Exec(), Query()等,使得开发人员能够以相同的方式操作不同的数据库。这大大提高了代码的可移植性和灵活性。
  2. 驱动支持database/sql包本身并不直接与数据库通信,而是依赖于第三方数据库驱动程序。这些驱动程序需要实现database/sql/driver包中定义的Driver接口,并在程序初始化阶段通过sql.Register()方法注册到database/sql中。常见的关系型数据库如MySQL、PostgreSQL、Oracle、Gbase8s等都有对应的Go语言驱动程序。比如oracle的驱动mattn/go-oci8: Oracle driver for Go using database/sql (github.com)
  3. 连接池管理database/sql维护了一个数据库连接池,用于管理数据库连接。当通过sql.Open()打开一个数据库连接时,database/sql会在合适的时机调用注册的驱动来创建一个具体的连接,并将其添加到连接池中。连接池会负责连接的复用、管理和维护工作,并且这是并发安全的。
  4. 事务支持database/sql包还支持事务处理,可以通过Tx类型的方法如Begin(), Commit(), Rollback()等来进行事务的管理。
  5. 安全性:为了防止SQL注入攻击,database/sql包推荐使用预编译语句和参数化查询。这样可以确保所有的SQL语句在执行前都会被预先分析和编译,从而避免了潜在的安全问题。

建立数据库连接

package demoimport ("database/sql"
)var mydb,_ =  sql.Open("mysql","connection_string")

检测连接是否能ping通

err = db.Ping()
if err != nil {panic(err)
}

通过连接进行具体的sql查询

func testSelect(db *sql.DB) error {rows, err := db.Query("select 3.14, 'foo' from dual")if err != nil {return err}defer rows.Close()for rows.Next() {var f1 float64var f2 stringrows.Scan(&f1, &f2)println(f1, f2) // 3.14 foo}return nil
}
//当然 对于不同的查询需求使用的函数不一样 这里就当你使用的时候直接去搜就好啦
//比如 需要返回值时
var primary string
err := c.db.QueryRow("select ha_primary from sysha_type").Scan(&primary)

查询完将连接进行关闭

db.Close()

当数据库宕掉重启后再次查询

if err = testSelect(db); err != nil {fmt.Println(err)return}

大家应该发现了再次查询和查询语句是一样的。其实对于执行上,都是执行的查询语句。但是我们需要考虑的是经历过数据库宕掉之后,还是传原来的db吗?那么就引出下一个问题。

database/sql包创建的db连接 对于数据库宕掉后重启是否仍然有效?

当数据库宕掉后重启,原先由database/sql包创建的db连接并不会自动恢复其有效性。在Go语言中,database/sql包提供了与SQL数据库进行交互的功能,其中包括连接池的管理。连接池负责维护打开的数据库连接,以便在多个数据库操作之间重用这些连接,从而提高应用程序的性能。然而,当数据库宕机并重新启动后,原有的数据库连接将不再有效,需要重新建立连接。以下是具体分析:

  1. 数据库连接状态检测
    • 在正常情况下,database/sql的连接池会维护一定数量的活跃和空闲连接。
    • db.SetMaxIdleConns()用于设置连接池中空闲连接的最大数量。
    • db.SetMaxOpenConns()用于设置到数据库的同时最大打开连接数。
    • db.SetConnMaxLifetime()可以设置连接的最大生命周期,超过这个时间,连接将被关闭并从池中移除。
  2. 数据库宕机影响
    • 当数据库宕机时,所有现有的数据库连接将会失效。
    • 即使数据库随后重启,这些失效的连接也不会自动恢复其有效性。
  3. 数据库重启处理
    • 在数据库重启后,必须创建新的数据库连接以替换失效的连接。
    • database/sql包本身不提供自动重连功能,因此需要在应用程序逻辑中处理这种情况。
  4. 连接池参数配置
    • 通过合理配置连接池参数,如最大空闲连接数、最大打开连接数和连接最大生命周期,可以优化数据库连接的使用效率。
    • 这些参数的设置应根据应用程序的具体需求和数据库的实际性能进行调整。
  5. 异常情况处理
    • 应用程序应具备异常处理机制,能够在数据库不可用时进行适当的错误处理和重试逻辑。
    • 可以考虑实现自定义的重连策略,例如指数退避算法,以避免在数据库重启期间过多地尝试连接。
  6. 测试与验证
    • 在开发过程中,应通过模拟数据库宕机和重启的场景来测试应用程序的异常处理能力。
    • 确保在实际部署前,应用程序能够正确处理数据库连接失效的情况。

所以,正确的执行步骤应该是,ping时发现db连接失效了,不通了,执行close操作,再次使用Open打开新的连接,ping检查db连接是否有效,再进行查询。

这篇关于一文理清database/sql包的使用场景和宕机查询流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1002468

相关文章

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤