📣
TiDB Cloud Essential 开放公测中。此页面由 AI 自动翻译,英文原文请见此处。

使用 mysql.js 连接 TiDB



TiDB 是兼容 MySQL 的数据库,mysql.js 驱动是一个纯 Node.js JavaScript 客户端,实现了 MySQL 协议。

在本教程中,你可以学习如何使用 TiDB 和 mysql.js 驱动完成以下任务:

  • 搭建你的开发环境。
  • 使用 mysql.js 驱动连接到你的 TiDB 集群。
  • 构建并运行你的应用程序。你还可以在 示例代码片段 中找到基本 CRUD 操作的代码示例。

前置条件

完成本教程,你需要:

  • 在你的机器上安装 Node.js >= 16.x。
  • 在你的机器上安装 Git
  • 一个正在运行的 TiDB 集群。

如果你还没有 TiDB 集群,可以按如下方式创建:

运行示例应用连接 TiDB

本节演示如何运行示例应用代码并连接到 TiDB。

步骤 1:克隆示例应用仓库

在终端窗口中运行以下命令,克隆示例代码仓库:

git clone https://github.com/tidb-samples/tidb-nodejs-mysqljs-quickstart.git cd tidb-nodejs-mysqljs-quickstart

步骤 2:安装依赖

运行以下命令安装示例应用所需的依赖包(包括 mysqldotenv):

npm install
为已有项目安装依赖

如果是你的已有项目,运行以下命令安装依赖包:

npm install mysql dotenv --save

步骤 3:配置连接信息

根据你选择的 TiDB 部署方式,连接到你的 TiDB 集群。

    1. 进入 Clusters 页面,点击目标集群名称进入集群概览页。

    2. 点击右上角的 Connect,弹出连接对话框。

    3. 确保连接对话框中的配置与你的操作环境一致。

      • Connection Type 设置为 Public
      • Branch 设置为 main
      • Connect With 设置为 General
      • Operating System 与运行应用的操作系统一致。
    4. 如果你还未设置密码,点击 Generate Password 生成随机密码。

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

      cp .env.example .env
    6. 编辑 .env 文件,按如下方式设置环境变量,将对应的占位符 {} 替换为连接对话框中的参数:

      TIDB_HOST={host} TIDB_PORT=4000 TIDB_USER={user} TIDB_PASSWORD={password} TIDB_DATABASE=test TIDB_ENABLE_SSL=true
    7. 保存 .env 文件。

    1. 进入 Clusters 页面,点击目标集群名称进入集群概览页。

    2. 点击右上角的 Connect,弹出连接对话框。

    3. 在连接对话框中,从 Connection Type 下拉列表选择 Public,然后点击 CA cert 下载 CA 证书。

      如果你还未配置 IP 访问列表,点击 Configure IP Access List 或参考 配置 IP 访问列表 进行配置后再首次连接。

      除了 Public 连接类型,TiDB Cloud Dedicated 还支持 Private EndpointVPC Peering 连接类型。更多信息参见 连接到你的 TiDB Cloud Dedicated 集群

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

      cp .env.example .env
    5. 编辑 .env 文件,按如下方式设置环境变量,将对应的占位符 {} 替换为连接对话框中的参数:

      TIDB_HOST={host} TIDB_PORT=4000 TIDB_USER={user} TIDB_PASSWORD={password} TIDB_DATABASE=test TIDB_ENABLE_SSL=true TIDB_CA_PATH={downloaded_ssl_ca_path}
    6. 保存 .env 文件。

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

      cp .env.example .env
    2. 编辑 .env 文件,将对应的占位符 {} 替换为你的集群连接参数。示例配置如下:

      TIDB_HOST={host} TIDB_PORT=4000 TIDB_USER=root TIDB_PASSWORD={password} TIDB_DATABASE=test

      如果你在本地运行 TiDB,默认主机地址为 127.0.0.1,密码为空。

    3. 保存 .env 文件。

    步骤 4:运行代码并查看结果

    运行以下命令执行示例代码:

    npm start

    如果连接成功,控制台会输出 TiDB 集群的版本信息,如下所示:

    🔌 Connected to TiDB cluster! (TiDB version: 8.0.11-TiDB-v8.5.4) ⏳ Loading sample game data... ✅ Loaded sample game data. 🆕 Created a new player with ID 12. ℹ️ Got Player 12: Player { id: 12, coins: 100, goods: 100 } 🔢 Added 50 coins and 50 goods to player 12, updated 1 row. 🚮 Deleted 1 player data.

    示例代码片段

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

    完整示例代码及运行方式请参考 tidb-samples/tidb-nodejs-mysqljs-quickstart 仓库。

    使用连接参数连接

    以下代码通过环境变量定义的参数连接 TiDB:

    // Step 1. Import the 'mysql' and 'dotenv' packages. import { createConnection } from "mysql"; import dotenv from "dotenv"; import * as fs from "fs"; // Step 2. Load environment variables from .env file to process.env. dotenv.config(); // Step 3. Create a connection to the TiDB cluster. const options = { host: process.env.TIDB_HOST || '127.0.0.1', port: process.env.TIDB_PORT || 4000, user: process.env.TIDB_USER || 'root', password: process.env.TIDB_PASSWORD || '', database: process.env.TIDB_DATABASE || 'test', ssl: process.env.TIDB_ENABLE_SSL === 'true' ? { minVersion: 'TLSv1.2', ca: process.env.TIDB_CA_PATH ? fs.readFileSync(process.env.TIDB_CA_PATH) : undefined } : null, } const conn = createConnection(options); // Step 4. Perform some SQL operations... // Step 5. Close the connection. conn.end();

    插入数据

    以下查询会创建一条 Player 记录,并返回新建记录的 ID:

    conn.query('INSERT INTO players (coins, goods) VALUES (?, ?);', [100, 100], (err, ok) => { if (err) { console.error(err); } else { console.log(ok.insertId); } });

    更多信息请参考 插入数据

    查询数据

    以下查询会根据 ID 1 返回一条 Player 记录:

    conn.query('SELECT id, coins, goods FROM players WHERE id = ?;', [1], (err, rows) => { if (err) { console.error(err); } else { console.log(rows[0]); } });

    更多信息请参考 查询数据

    更新数据

    以下查询会为 ID 为 1Player 增加 50 个 coins 和 50 个 goods:

    conn.query( 'UPDATE players SET coins = coins + ?, goods = goods + ? WHERE id = ?;', [50, 50, 1], (err, ok) => { if (err) { console.error(err); } else { console.log(ok.affectedRows); } } );

    更多信息请参考 更新数据

    删除数据

    以下查询会删除 ID 为 1Player 记录:

    conn.query('DELETE FROM players WHERE id = ?;', [1], (err, ok) => { if (err) { reject(err); } else { resolve(ok.affectedRows); } });

    更多信息请参考 删除数据

    实用说明

    • 使用 连接池 管理数据库连接,可以减少频繁建立和销毁连接带来的性能开销。

    • 为避免 SQL 注入攻击,建议在执行 SQL 前使用 转义查询参数

    • 在 SQL 语句不复杂的场景下,使用 ORM 框架可以提升开发效率,例如:SequelizeTypeORMPrisma

    • 在处理数据库中的大数(BIGINTDECIMAL 列)时,建议启用 supportBigNumbers: true 选项。

    后续步骤

    需要帮助?

    欢迎在 DiscordSlack 社区提问,或 提交支持工单

    文档内容是否有帮助?