在Debian上折腾Golang连接数据库这事儿,说白了就四个步骤:装好Go、装对驱动、写好代码、跑起来。别看步骤简单,每一步都有不少细节值得留意。

先说第一步,Golang本身。如果你还没装,去官方页面(golang.org/dl)下载对应的Linux版本,解压配置一下环境变量就行。Debian用户也可以用apt,不过官方推荐手动安装,版本更可控。
第二步,装数据库驱动。这个根据你用的数据库来选,Golang社区维护了一堆成熟的驱动:
- MySQL:
go get -u github.com/go-sql-driver/mysql - PostgreSQL:
go get -u github.com/lib/pq - SQLite:
go get -u github.com/mattn/go-sqlite3 - MongoDB:
go get -u go.mongodb.org/mongo-driver/mongo
驱动装好之后,代码怎么写才是重头戏。下面拿MySQL举例子,思路完全通用:
package main
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
func main() {
// 连接数据库
dsn := "username:password@tcp(localhost:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local"
db, err := sql.Open("mysql", dsn)
if err != nil {
panic(err)
}
defer db.Close()
// 测试连接
err = db.Ping()
if err != nil {
panic(err)
}
fmt.Println("Connected to the database!")
// 查询
rows, err := db.Query("SELECT * FROM users")
if err != nil {
panic(err)
}
defer rows.Close()
// 处理结果
for rows.Next() {
var id int
var name string
err = rows.Scan(&id, &name)
if err != nil {
panic(err)
}
fmt.Printf("User: %d, %s\n", id, name)
}
if err = rows.Err(); err != nil {
panic(err)
}
}这段代码完成了连接、测试、查询、结果遍历的整个链路。注意,dsn里的参数可以根据实际情况调整——比如charset、parseTime、loc这些,在生产环境尤其重要。
最后一步,编译运行。终端里切到你的Go文件目录,执行go run main.go,如果不出意外,你应该能看到数据被打印出来。
当然,实际项目里几乎不会把数据库连接信息硬编码在代码中。更靠谱的做法是用配置文件、环境变量,甚至专门的配置中心来管理。另外,连接池、错误重试、日志监控这些机制,也是生产环境必须考虑的点。不过对于入门示例来说,上面的逻辑已经足够清晰了。
