使用事务回滚确保测试隔离,通过传入*sql.Tx实现数据操作函数的可测试性,结合sqlmock模拟SQL验证逻辑,保证测试可重复且无副作用。

测试数据库操作在 Golang 中是确保数据层逻辑正确的重要环节。关键在于隔离真实环境、使用事务控制以及合理模拟数据。以下是具体实践方法。
避免影响生产或开发数据库,测试时应使用独立的数据库实例,或在事务中运行测试并在结束后回滚。
常见做法是在测试开始时创建一个事务,所有操作在此事务中进行,测试结束调用 Rollback() 清理数据。
这样每个测试都是干净且独立的,不会相互干扰。
立即学习“go语言免费学习笔记(深入)”;
为了让函数更容易被测试,应避免直接依赖全局 *sql.DB,而是通过参数传入 *sql.DB 或 *sql.Tx。
例如:
func CreateUser(db *sql.DB, name string) error {
_, err := db.Exec("INSERT INTO users (name) VALUES (?)", name)
return err
}
测试时就可以传入事务对象代替 DB 实例。
一个类似淘宝助理、ebay助理的客户端程序,用来方便的在本地处理商店数据,并能够在本地商店、网上商店和第三方平台之间实现数据上传下载功能的工具。功能说明如下:1.连接本地商店:您可以使用ShopEx助理连接一个本地安装的商店系统,这样就可以使用助理对本地商店的商品数据进行编辑等操作,并且数据也将存放在本地商店数据库中。默认是选择“本地未安装商店”,本地还未安
0
若不想连接真实数据库,可以使用 sqlmock 库模拟 SQL 执行过程。
它能验证 SQL 语句、参数是否正确,并返回预设结果。
适合单元测试,但不能替代集成测试。
假设有一个插入用户的方法:
func TestCreateUser(t *testing.T) {
db, err := sql.Open("mysql", "user:password@tcp(localhost:3306)/test_db")
if err != nil {
t.Fatal(err)
}
defer db.Close()
tx, err := db.Begin()
if err != nil {
t.Fatal(err)
}
defer tx.Rollback() // 确保测试后数据不残留
err = CreateUser(tx, "alice")
if err != nil {
t.Errorf("expected no error, got %v", err)
}
var count int
err = tx.QueryRow("SELECT COUNT(*) FROM users WHERE name = ?", "alice").Scan(&count)
if err != nil {
t.Fatal(err)
}
if count != 1 {
t.Errorf("expected 1 user, got %d", count)
}
}
这个测试既验证了逻辑,也确认了数据写入正确。
基本上就这些。核心是控制数据状态,保证测试可重复、无副作用。
以上就是如何使用Golang测试数据库操作的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号