Go 语言高效连接 MySQL 数据库:从入门到实战

在 Go 语言的开发过程中,与 MySQL 数据库的交互是常见需求之一。本文将深入讲解如何使用 Go 语言高效、安全地连接 MySQL 数据库,并进行数据操作。

1. 安装 MySQL 驱动

Go 语言通常使用 github.com/go-sql-driver/mysql 作为 MySQL 驱动,首先需要安装它:

go 复制代码
go get -u github.com/go-sql-driver/mysql

2. 连接 MySQL 数据库

在 Go 代码中,使用 database/sql 包结合 go-sql-driver/mysql 进行数据库连接。

go 复制代码
package main

import (
    "database/sql"
    "fmt"
    "log"
    "time"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    // 配置 MySQL 连接信息
    dsn := "user:password@tcp(127.0.0.1:3306)/dbname"
    db, err := sql.Open("mysql", dsn)
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    // 设置连接池参数
    db.SetMaxOpenConns(100) // 最大打开连接数
    db.SetMaxIdleConns(10)  // 最大空闲连接数
    db.SetConnMaxLifetime(60 * time.Second) // 连接最大存活时间

    // 测试连接是否成功
    if err := db.Ping(); err != nil {
        log.Fatal(err)
    }
    fmt.Println("成功连接到 MySQL 数据库!")

    // 插入数据
    insertQuery := "INSERT INTO users(name, age) VALUES(?, ?)"
    result, err := db.Exec(insertQuery, "张三", 28)
    if err != nil {
        log.Fatal(err)
    }
    lastInsertID, _ := result.LastInsertId()
    fmt.Println("插入成功,ID:", lastInsertID)

    // 查询数据
    selectQuery := "SELECT id, name, age FROM users WHERE age > ?"
    rows, err := db.Query(selectQuery, 20)
    if err != nil {
        log.Fatal(err)
    }
    defer rows.Close()

    for rows.Next() {
        var id int
        var name string
        var age int
        err := rows.Scan(&id, &name, &age)
        if err != nil {
            log.Fatal(err)
        }
        fmt.Printf("ID: %d, Name: %s, Age: %d\n", id, name, age)
    }

    // 事务处理
    tx, err := db.Begin()
    if err != nil {
        log.Fatal(err)
    }

    _, err = tx.Exec("UPDATE accounts SET balance = balance - ? WHERE id = ?", 100, 1)
    if err != nil {
        tx.Rollback()
        log.Fatal(err)
    }

    _, err = tx.Exec("UPDATE accounts SET balance = balance + ? WHERE id = ?", 100, 2)
    if err != nil {
        tx.Rollback()
        log.Fatal(err)
    }

    err = tx.Commit()
    if err != nil {
        log.Fatal(err)
    }
    fmt.Println("事务提交成功!")
}

3. 结论

本文介绍了 Go 语言连接 MySQL 数据库的完整流程,包括驱动安装、基本 CRUD 操作、连接池优化和事务处理等。希望能帮助你更高效地使用 Go 进行数据库开发!

相关推荐
陈随易11 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
IT_陈寒13 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰14 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
这个DBA有点耶14 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
用户83562907805114 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
小满zs14 小时前
Go语言第二章(小无相功)
后端·go
用户83562907805114 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
karry_k15 小时前
MyBatis批量insert-select踩坑:useGeneratedKeys=true 可能让PostgreSQL返回大量插入结果
java·后端
妙码生花15 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
老鹰86215 小时前
Google Wire 被官方抛弃,Uber Fx 启动就 panic,Go DI 还有救吗?
go