English | 中文
This is an example project by PingCAP that demonstrates connecting to TiDB using Spring Boot and Spring Data JPA. Additionally, this project utilizes Hibernate as the provider for Spring Data JPA.
TiDB is a MySQL-compatible database. Spring is a popular open-source Java container framework, and we've chosen to use Spring Boot as the way to use Spring.
- Recommended Java Development Kit (JDK) version 17 or above. You can choose OpenJDK or Oracle JDK based on your company and personal needs.
- Maven version 3.8 or above.
- Git.
- TiDB cluster. If you don't have a TiDB cluster yet, you can create one using the following methods:
- (Recommended) Refer to Create TiDB Serverless Cluster to create your own TiDB Cloud cluster.
- Refer to Deploy a Local Testing TiDB Cluster or Deploy a Production TiDB Cluster to create a local cluster.
git clone https://github.com/tidb-samples/tidb-java-springboot-jpa-quickstart.git
cd tidb-java-springboot-jpa-quickstart
(Option 1) TiDB Serverless
-
In the TiDB Cloud console, open the Clusters page, select your TiDB Serverless cluster, go to the Overview page, and click the Connect button in the upper right corner.
-
Ensure that the configuration in the window matches your runtime environment.
- Endpoint Type is Public
- Connect With is General
- Operating System matches your runtime environment
If you are running in Windows Subsystem for Linux (WSL), switch to the corresponding Linux distribution.
-
Click Generate password to generate a password.
If you have generated a password before, you can use the original password or click Reset Password to generate a new one.
-
Run the following command to copy and rename
env.sh.example
toenv.sh
:cp env.sh.example env.sh
-
Copy and paste the corresponding connection string into
env.sh
. Change the example results as follows.export TIDB_HOST='{gateway-region}.aws.tidbcloud.com' export TIDB_PORT='4000' export TIDB_USER='{prefix}.root' export TIDB_PASSWORD='{password}' export TIDB_DB_NAME='test' export USE_SSL='true'
Replace placeholders
{}
with values obtained from the Connect window.TiDB Serverless requires the use of a secure connection, so the value of
USE_SSL
should be set totrue
. -
Save the file.
(Option 2) TiDB Dedicated
-
In the TiDB Cloud Web Console, select your TiDB Dedicated cluster, go to the Overview page, click the Connect button in the upper right corner. Click Allow Access from Anywhere.
For more configuration details, refer to TiDB Dedicated Standard Connection Guide.
-
Run the following command to copy and rename
env.sh.example
toenv.sh
:cp env.sh.example env.sh
-
Copy and paste the corresponding connection string into
env.sh
. Change the example results as follows.export TIDB_HOST='{host}.clusters.tidb-cloud.com' export TIDB_PORT='4000' export TIDB_USER='{prefix}.root' export TIDB_PASSWORD='{password}' export TIDB_DB_NAME='test' export USE_SSL='false'
Replace placeholders
{}
with values obtained from the Connect window, and configure the certificate path downloaded in previous steps. -
Save the file.
(Option 3) Self-Hosted TiDB
-
Run the following command to copy and rename
env.sh.example
toenv.sh
:cp env.sh.example env.sh
-
Copy and paste the corresponding connection string into
env.sh
. Change the example results as follows.export TIDB_HOST='{tidb_server_host}' export TIDB_PORT='4000' export TIDB_USER='root' export TIDB_PASSWORD='{password}' export TIDB_DB_NAME='test' export USE_SSL='false'
Replace placeholders
{}
with values corresponding to your TiDB setup. If you are running TiDB on your local machine, the default Host address is127.0.0.1
, and the password is empty. -
Save the file.
-
Run the following command to start the service written in the example code:
make
-
Open another terminal and initiate the request script:
make request
Regarding the third-party libraries and frameworks used, you can refer to their respective official documentation:
- Spring Framework Official Documentation
- Spring Boot Official Documentation
- Spring Data JPA Official Documentation
- Hibernate Official Documentation
- You can continue reading the developer documentation to gain more knowledge about TiDB. For example: Insert Data, Update Data, Delete Data, Read from a Single Table, Transactions, SQL Performance Optimization.
- If you prefer a structured learning approach, we provide professional course for Java developers: Working with TiDB from Java.