使用 MySQL Connector/Python 连接到平凯数据库

平凯数据库是一个兼容 MySQL 的数据库。MySQL Connector/Python 是由 MySQL 开发的 Python Driver。

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

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

前置需求

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

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

本小节演示如何运行示例应用程序的代码,并连接到 TiDB。

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

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

git clone https://github.com/tidb-samples/tidb-python-mysqlconnector-quickstart.git cd tidb-python-mysqlconnector-quickstart

第 2 步:安装依赖

运行以下命令,安装示例代码所需要的依赖(包括 mysql-connector-python):

pip install -r requirements.txt

第 3 步:配置连接信息

  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'

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

  3. 保存 .env 文件。

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

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

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

示例代码片段

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

完整代码及其运行方式,见代码仓库 tidb-samples/tidb-python-mysqlconnector-quickstart。

连接到平凯数据库

def get_connection(autocommit: bool = True) -> MySQLConnection: db_conf = { "host": '${tidb_host}', "port": '${tidb_port}', "user": '${tidb_user}', "password": '${tidb_password}', "database": '${tidb_db_name}', "autocommit": autocommit, "use_pure": True, } if '${ca_path}': db_conf["ssl_verify_cert"] = True db_conf["ssl_verify_identity"] = True db_conf["ssl_ca"] = '${ca_path}' return mysql.connector.connect(**db_conf)

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

插入数据

with get_connection(autocommit=True) as conn: with conn.cursor() as cur: player = ("test", 1, 1) cursor.execute("INSERT INTO players (id, coins, goods) VALUES (%s, %s, %s)", player)

更多信息参考插入数据

查询数据

with get_connection(autocommit=True) as conn: with conn.cursor() as cur: cur.execute("SELECT count(*) FROM players") print(cur.fetchone()[0])

更多信息参考查询数据

更新数据

with get_connection(autocommit=True) as conn: with conn.cursor() as cur: player_id, amount, price="test", 10, 500 cur.execute( "UPDATE players SET goods = goods + %s, coins = coins + %s WHERE id = %s", (-amount, price, player_id), )

更多信息参考更新数据

删除数据

with get_connection(autocommit=True) as conn: with conn.cursor() as cur: player_id = "test" cur.execute("DELETE FROM players WHERE id = %s", (player_id,))

更多信息参考删除数据

注意事项

使用驱动程序还是 ORM 框架?

Python 驱动程序提供对数据库的底层访问,但要求开发者:

  • 手动建立和释放数据库连接
  • 手动管理数据库事务
  • 手动将数据行(在 mysql-connector-python 中表示为元组 (Tuple) 或者字典 (Dictionary))映射为数据对象

建议仅在需要编写复杂的 SQL 语句时使用驱动程序。其他情况下,建议使用 ORM 框架进行开发,例如 SQLAlchemyPeeweeDjango。ORM 可以帮助你:

  • 减少管理连接和事务的模板代码
  • 使用数据对象代替大量 SQL 语句来操作数据

下一步

需要帮助?

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