Go 语言高效连接 SQL Server(MSSQL)数据库实战指南

在 Go 语言的开发过程中,与 Microsoft SQL Server (MSSQL) 数据库的交互是常见需求之一。本文将详细介绍如何使用 Go 语言高效、安全地连接 SQL Server,并进行基本的 CRUD(增删改查)操作。

1. 安装 MSSQL 驱动

Go 语言使用 github.com/denisenkom/go-mssqldb 作为 SQL Server 驱动,首先需要安装它:

go 复制代码
go get -u github.com/denisenkom/go-mssqldb

2. 连接 MSSQL 数据库

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

go 复制代码
package main

import (
    "database/sql"
    "fmt"
    "log"
    _ "github.com/denisenkom/go-mssqldb"
)

func main() {
    // 配置 SQL Server 连接信息
    server := "localhost"
    port := 1433
    user := "sa"
    password := "your_password"
    database := "your_db"

    dsn := fmt.Sprintf("server=%s;port=%d;user id=%s;password=%s;database=%s;encrypt=disable",
        server, port, user, password, database)
    
    db, err := sql.Open("sqlserver", dsn)
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

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

3. 执行 SQL 查询

插入数据

css 复制代码
query := "INSERT INTO users (name, age) VALUES (@p1, @p2)"
result, err := db.Exec(query, "李四", 30)
if err != nil {
    log.Fatal(err)
}
lastInsertID, _ := result.LastInsertId()
fmt.Println("插入成功,ID:", lastInsertID)

查询数据

go 复制代码
query := "SELECT id, name, age FROM users WHERE age > @p1"
rows, err := db.Query(query, 25)
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)
}

4. 连接池优化

在高并发场景下,合理配置数据库连接池参数可以提升性能。

scss 复制代码
db.SetMaxOpenConns(100) // 最大打开连接数
db.SetMaxIdleConns(10)  // 最大空闲连接数
db.SetConnMaxLifetime(60 * time.Second) // 连接最大存活时间

5. 事务处理

scss 复制代码
tx, err := db.Begin()
if err != nil {
    log.Fatal(err)
}

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

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

tx.Commit()
fmt.Println("事务提交成功!")

6. 结论

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

相关推荐
Moment6 分钟前
Cursor 的 5 种指令方法比较,你最喜欢哪一种?
前端·后端·github
IT_陈寒9 分钟前
Vite快得离谱?揭秘它比Webpack快10倍的5个核心原理
前端·人工智能·后端
摸鱼的春哥1 小时前
Agent教程17:LangChain的持久化和人工干预
前端·javascript·后端
风象南1 小时前
OpenClaw 登顶 GitHub Star 榜首:一个程序员 13 年后的"重新点火"故事
人工智能·后端
Victor3561 小时前
MongoDB(25)什么是单字段索引?
后端
Victor3561 小时前
MongoDB(26)什么是复合索引?
后端
程序员爱钓鱼2 小时前
Go操作Excel实战详解:github.com/xuri/excelize/v2
前端·后端·go
oak隔壁找我10 小时前
MySQL中 SHOW FULL PROCESSLIST` 输出中 `State` 列的所有可能值
后端
上进小菜猪10 小时前
基于 YOLOv8 的面向文档智能处理的表格区域检测系统 [目标检测完整源码]
后端
oak隔壁找我11 小时前
JVM常用调优参数
java·后端