使用 Go-MySQL-Driver 连接到 TiDB
TiDB 是一个兼容 MySQL 的数据库。Go-MySQL-Driver 是 database/sql 接口的 MySQL 实现。
本文档将展示如何使用 TiDB 和 Go-MySQL-Driver 来完成以下任务:
- 配置你的环境。
- 使用 Go-MySQL-Driver 连接到 TiDB 集群。
- 构建并运行你的应用程序。你也可以参考示例代码片段,完成基本的 CRUD 操作。
前置需求
- 推荐 Go 1.20 及以上版本。
- Git。
- TiDB 集群。如果你还没有 TiDB 集群,可以按照以下方式创建:
- (推荐方式)参考创建 TiDB Serverless 集群,创建你自己的 TiDB Cloud 集群。
- 参考部署本地测试 TiDB 集群或部署正式 TiDB 集群,创建本地集群。
运行代码并连接到 TiDB
本小节演示如何运行示例应用程序的代码,并连接到 TiDB。
第 1 步:克隆示例代码仓库到本地
运行以下命令,将示例代码仓库克隆到本地:
git clone https://github.com/tidb-samples/tidb-golang-sql-driver-quickstart.git
cd tidb-golang-sql-driver-quickstart
第 2 步:配置连接信息
根据不同的 TiDB 部署方式,使用不同的方法连接到 TiDB 集群。
- TiDB Serverless
- TiDB Dedicated
- 本地部署 TiDB
在 TiDB Cloud 的 Clusters 页面中,选择你的 TiDB Serverless 集群,进入集群的 Overview 页面。
点击右上角的 Connect 按钮,将会弹出连接对话框。
确认对话框中的配置和你的运行环境一致。
- Endpoint Type 为
Public
。 - Connect With 选择
General
。 - Operating System 为你的运行环境。
- Endpoint Type 为
如果你还没有设置密码,点击 Create password 生成一个随机密码。
运行以下命令,将
.env.example
复制并重命名为.env
:cp .env.example .env复制并粘贴对应连接字符串至
.env
中。示例结果如下:TIDB_HOST='{host}' # e.g. gateway01.ap-northeast-1.prod.aws.tidbcloud.com TIDB_PORT='4000' TIDB_USER='{user}' # e.g. xxxxxx.root TIDB_PASSWORD='{password}' TIDB_DB_NAME='test' USE_SSL='true'注意替换
{}
中的占位符为连接对话框中获得的值。TiDB Serverless 要求使用 TLS (SSL) connection,因此
USE_SSL
的值应为true
。保存
.env
文件。
在 TiDB Cloud 的 Clusters 页面中,选择你的 TiDB Dedicated 集群,进入集群的 Overview 页面。
点击右上角的 Connect 按钮,将会出现连接对话框。
在对话框中点击 Allow Access from Anywhere。
更多配置细节,可参考 TiDB Dedicated 标准连接教程(英文)。
运行以下命令,将
.env.example
复制并重命名为.env
:cp .env.example .env复制并粘贴对应的连接字符串至
.env
中。示例结果如下:TIDB_HOST='{host}' # e.g. tidb.xxxx.clusters.tidb-cloud.com TIDB_PORT='4000' TIDB_USER='{user}' # e.g. root TIDB_PASSWORD='{password}' TIDB_DB_NAME='test' USE_SSL='false'注意替换
{}
中的占位符为连接对话框中获得的值。保存
.env
文件。
运行以下命令,将
.env.example
复制并重命名为.env
:cp .env.example .env复制并粘贴对应 TiDB 的连接字符串至
.env
中。示例结果如下:TIDB_HOST='{host}' TIDB_PORT='4000' TIDB_USER='root' TIDB_PASSWORD='{password}' TIDB_DB_NAME='test' USE_SSL='false'注意替换
{}
中的占位符为你的 TiDB 对应的值,并设置USE_SSL
为false
。如果你在本机运行 TiDB,默认 Host 地址为127.0.0.1
,密码为空。保存
.env
文件。
第 3 步:运行代码并查看结果
运行下述命令,执行示例代码:
make查看
Expected-Output.txt
,并与你的程序输出进行比较。结果近似即为连接成功。
示例代码片段
你可参考以下关键代码片段,完成自己的应用开发。
完整代码及其运行方式,见代码仓库 tidb-golang-sql-driver-quickstart。
连接到 TiDB
func openDB(driverName string, runnable func(db *sql.DB)) {
dsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=utf8mb4&tls=%s",
${tidb_user}, ${tidb_password}, ${tidb_host}, ${tidb_port}, ${tidb_db_name}, ${use_ssl})
db, err := sql.Open(driverName, dsn)
if err != nil {
panic(err)
}
defer db.Close()
runnable(db)
}
在使用该函数时,你需要将 ${tidb_host}
、${tidb_port}
、${tidb_user}
、${tidb_password}
、${tidb_db_name}
等替换为你的 TiDB 集群的实际值。因为 TiDB Serverless 要求使用 TLS (SSL) connection,因此在连接到 TiDB Serverless 时 ${use_ssl}
的值应为 true
。
插入数据
openDB("mysql", func(db *sql.DB) {
insertSQL = "INSERT INTO player (id, coins, goods) VALUES (?, ?, ?)"
_, err := db.Exec(insertSQL, "id", 1, 1)
if err != nil {
panic(err)
}
})
更多信息参考插入数据。
查询数据
openDB("mysql", func(db *sql.DB) {
selectSQL = "SELECT id, coins, goods FROM player WHERE id = ?"
rows, err := db.Query(selectSQL, "id")
if err != nil {
panic(err)
}
// This line is extremely important!
defer rows.Close()
id, coins, goods := "", 0, 0
if rows.Next() {
err = rows.Scan(&id, &coins, &goods)
if err == nil {
fmt.Printf("player id: %s, coins: %d, goods: %d\n", id, coins, goods)
}
}
})
更多信息参考查询数据。
更新数据
openDB("mysql", func(db *sql.DB) {
updateSQL = "UPDATE player set goods = goods + ?, coins = coins + ? WHERE id = ?"
_, err := db.Exec(updateSQL, 1, -1, "id")
if err != nil {
panic(err)
}
})
更多信息参考更新数据。
删除数据
openDB("mysql", func(db *sql.DB) {
deleteSQL = "DELETE FROM player WHERE id=?"
_, err := db.Exec(deleteSQL, "id")
if err != nil {
panic(err)
}
})
更多信息参考删除数据。
注意事项
使用驱动程序还是 ORM 框架?
Golang 驱动程序提供对数据库的底层访问,但要求开发者:
- 手动建立和释放数据库连接
- 手动管理数据库事务
- 手动将数据行映射为数据对象
建议仅在需要编写复杂的 SQL 语句时使用驱动程序。其他情况下,建议使用 ORM 框架进行开发,例如 GORM。ORM 可以帮助你:
- 减少管理连接和事务的模板代码
- 使用数据对象代替大量 SQL 语句来操作数据
下一步
- 关于 Go-MySQL-Driver 的更多使用方法,可以参考 Go-MySQL-Driver 官方文档。
- 你可以继续阅读开发者文档,以获取更多关于 TiDB 应用开发的最佳实践。例如:插入数据、更新数据、删除数据、单表读取、事务、SQL 性能优化等。
- 如果你更倾向于参与课程进行学习,我们也提供专业的 TiDB 开发者课程支持,并在考试后提供相应的资格认证。
需要帮助?
如果在开发的过程中遇到问题,可以在 AskTUG 上进行提问,寻求帮助。