English | 中文
This a sample project written by PingCAP for peewee to connect to TiDB.
TiDB is a MySQL-compatible database, and peewee is a popular Object Relational Mapper (ORM) for Python.
- Python 3.8 or higher
- Git
- A TiDB cluster. If you don't have a TiDB cluster, you can create one as follows:
- (Recommended) Follow Creating a TiDB Serverless Cluster to create your own TiDB Cloud cluster.
- Follow Deploy a Local Test TiDB Cluster or Deploy a Production TiDB Cluster to create a local cluster
git clone https://github.com/tidb-samples/tidb-python-peewee-quickstart.git
cd tidb-python-peewee-quickstart
pip install -r requirements.txt
Peewee is an ORM library that works with multiple databases. It provides a high-level abstraction of the database, which helps developers write SQL statements in a more object-oriented way. However, peewee does not include a database driver. To connect to a database, you need to install a database driver. This sample application uses PyMySQL as the database driver, which is a pure Python MySQL client library that is compatible with TiDB and can be installed on all platforms. For more information, refer to peewee official documentation.
(Option 1) TiDB Serverless
-
In the TiDB Cloud, navigate to the Clusters page, select your TiDB Serverless cluster. Go to the Overview page, and click the Connect button in the upper right corner.
-
Ensure the configurations in the confirmation window match your operating environment.
- Endpoint Type is set to Public
- Connect With is set to General
- Operating System matches your environment
If you are running in Windows Subsystem for Linux (WSL), switch to the corresponding Linux distribution.
-
Click Create password to create a password.
If you have created a password before, you can either use the original password or click Reset Password to generate a new one.
-
Run the following command to copy
.env.example
and rename it to.env
:cp .env.example .env
-
Copy and paste the corresponding connection string into the
.env
file. Example result is as follows:TIDB_HOST='{gateway-region}.aws.tidbcloud.com' TIDB_PORT='4000' TIDB_USER='{prefix}.root' TIDB_PASSWORD='{password}' TIDB_DB_NAME='test' CA_PATH='{ca_path}'
Be sure to replace the placeholders
{}
with the values obtained from the connection dialog.TiDB Serverless requires a secure connection, you can refer to the TLS Connections to TiDB Serverless to get the certificate paths for different operating systems.
-
Save the
.env
file.
(Option 2) TiDB Dedicated
-
In the TiDB Cloud, select your TiDB Dedicated cluster. Go to the Overview page, and click the Connect button in the upper right corner. Click Allow Access from Anywhere and then click Download TiDB cluster CA to download the certificate.
For more configuration details, refer to TiDB Dedicated Standard Connection.
-
Run the following command to copy
.env.example
and rename it to.env
:cp .env.example .env
-
Copy and paste the corresponding connection string into the
.env
file. Example result is as follows:TIDB_HOST='{host}.clusters.tidb-cloud.com' TIDB_PORT='4000' TIDB_USER='{username}' TIDB_PASSWORD='{password}' TIDB_DB_NAME='test' CA_PATH='{your-downloaded-ca-path}'
Be sure to replace the placeholders
{}
with the values obtained from the Connect window, and configureCA_PATH
with the certificate path downloaded in the previous step. -
Save the
.env
file.
(Option 3) Self-Hosted TiDB
-
Run the following command to copy
.env.example
and rename it to.env
:cp .env.example .env
-
Copy and paste the corresponding connection string into the
.env
file. Example result is as follows:TIDB_HOST='{tidb_server_host}' TIDB_PORT='4000' TIDB_USER='root' TIDB_PASSWORD='{password}' TIDB_DB_NAME='test'
Be sure to replace the placeholders
{}
with the values, and remove theCA_PATH
line. If you are running TiDB locally, the default host address is127.0.0.1
, and the password is empty. -
Save the
.env
file.
python peewee_example.py
- You can continue reading the developer documentation to get more knowledge about TiDB development, such as: Insert Data, Update Data, Delete Data, Single Table Reading, Transactions, SQL Performance Optimization, etc.
- If you prefer to learn through courses, we also offer professional TiDB Developer Courses, and provide TiDB certifications after the exam.