使用 GORM 连接到平凯数据库

平凯数据库是一个兼容 MySQL 的数据库。GORM 是当前比较流行的开源 Golang ORM 框架并且适配了平凯数据库 的 AUTO_RANDOM 等特性。同时,平凯数据库 为 GORM 的默认支持数据库

本文档将展示如何使用平凯数据库和 GORM 来完成以下任务:

  • 配置你的环境。
  • 使用 GORM 连接到平凯数据库集群。
  • 构建并运行你的应用程序。你也可以参考示例代码片段,完成基本的 CRUD 操作。

前置需求

  • 推荐 Go 1.20 及以上版本。
  • Git
  • 平凯数据库集群。

如果你还没有平凯数据库集群,可以按如下方式创建一个:

运行代码并连接到平凯数据库

本小节演示如何运行示例应用程序的代码,并连接到平凯数据库。

第 1 步:克隆示例代码仓库到本地

运行以下命令,将示例代码仓库克隆到本地:

git clone https://github.com/tidb-samples/tidb-golang-gorm-quickstart.git cd tidb-golang-gorm-quickstart

第 2 步:配置连接信息

  1. 运行以下命令,将 .env.example 复制并重命名为 .env

    cp .env.example .env
  2. 复制并粘贴对应 TiDB 的连接字符串至 .env 中。示例结果如下:

    TIDB_HOST='{host}' TIDB_PORT='4000' TIDB_USER='root' TIDB_PASSWORD='{password}' TIDB_DB_NAME='test' USE_SSL='false'

    注意替换 {} 中的占位符为你的 TiDB 对应的值,并设置 USE_SSLfalse。如果你在本机运行 TiDB,默认 Host 地址为 127.0.0.1,密码为空。

  3. 保存 .env 文件。

第 3 步:运行代码并查看结果

  1. 运行下述命令,执行示例代码:

    make
  2. 查看 Expected-Output.txt,并与你的程序输出进行比较。结果近似即为连接成功。

示例代码片段

你可参考以下关键代码片段,完成自己的应用开发。

完整代码及其运行方式,见代码仓库 tidb-golang-gorm-quickstart。

连接到平凯数据库

func createDB() *gorm.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 := gorm.Open(mysql.Open(dsn), &gorm.Config{ Logger: logger.Default.LogMode(logger.Info), }) if err != nil { panic(err) } return db }

在使用该函数时,你需要将 ${tidb_host}${tidb_port}${tidb_user}${tidb_password}${tidb_db_name} 等替换为你的 TiDB 集群的实际值。

插入数据

db.Create(&Player{ID: "id", Coins: 1, Goods: 1})

更多信息参考插入数据

查询数据

var queryPlayer Player db.Find(&queryPlayer, "id = ?", "id")

更多信息参考查询数据

更新数据

db.Save(&Player{ID: "id", Coins: 100, Goods: 1})

更多信息参考更新数据

删除数据

db.Delete(&Player{ID: "id"})

更多信息参考删除数据

下一步

需要帮助?

如果在开发的过程中遇到问题,可以在 AskTUG 上进行提问,寻求帮助。