PingKai Logo下载

使用 Spring Boot 连接到 TiDB

TiDB 是一个兼容 MySQL 的数据库。Spring 是当前比较流行的开源 Java 容器框架,本文选择 Spring Boot 作为使用 Spring 的方式。

本文档将展示如何使用 TiDB 和 Spring Data JPAHibernate 作为 JPA 提供者来完成以下任务:

  • 配置你的环境。
  • 使用 Spring Data JPA 与 Hibernate 连接到 TiDB。
  • 构建并运行你的应用程序。你也可以参考示例代码片段,完成基本的 CRUD 操作。

前置需求

运行代码并连接到 TiDB

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

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

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

git clone https://github.com/tidb-samples/tidb-java-springboot-jpa-quickstart.git
cd tidb-java-springboot-jpa-quickstart

第 2 步:配置连接信息

根据不同的 TiDB 部署方式,使用不同的方法连接到 TiDB。

  1. 在 TiDB Cloud 的 My TiDB 页面中,选择你的 TiDB Cloud Starter 或 Essential 实例,进入实例的 Overview 页面。

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

  3. 确认对话框中的配置和你的运行环境一致。

    • Connection TypePublic
    • Branch 选择 main
    • Connect With 选择 General
    • Operating System 为你的运行环境。
  4. 如果你还没有设置密码,点击 Generate Password 生成一个随机密码。

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

    cp env.sh.example env.sh
  6. 复制并粘贴对应连接字符串至 env.sh 中。需更改部分示例结果如下:

    export TIDB_HOST='{host}'  # e.g. xxxxxx.aws.tidbcloud.com
    export TIDB_PORT='4000'
    export TIDB_USER='{user}'  # e.g. xxxxxx.root
    export TIDB_PASSWORD='{password}'
    export TIDB_DB_NAME='test'
    export USE_SSL='true'

    注意替换 {} 中的占位符为连接对话框中获得的值。

    TiDB Cloud Starter 要求使用 TLS (SSL) connection,因此 USE_SSL 的值应为 true

  7. 保存 env.sh 文件。

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

  1. 运行下述命令,启动示例代码编写的服务:

    make
  2. 打开另一个终端,开启请求脚本:

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

示例代码片段

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

完整代码及其运行方式,见代码仓库 tidb-java-springboot-jpa-quickstart

连接到 TiDB

编写配置文件 application.yml

spring:
  datasource:
    url: ${TIDB_JDBC_URL:jdbc:mysql://localhost:4000/test}
    username: ${TIDB_USER:root}
    password: ${TIDB_PASSWORD:}
    driver-class-name: com.mysql.cj.jdbc.Driver
  jpa:
    show-sql: true
    database-platform: org.hibernate.dialect.TiDBDialect
    hibernate:
      ddl-auto: create-drop

请在配置后将环境变量 TIDB_JDBC_URLTIDB_USERTIDB_PASSWORD 设置为你的 TiDB 的实际值。此配置文件带有环境变量默认配置,即在不配置环境变量时,变量的值为:

  • TIDB_JDBC_URL: "jdbc:mysql://localhost:4000/test"
  • TIDB_USER: "root"
  • TIDB_PASSWORD: ""

数据管理

Spring Data JPA 通过 @Entity 注册数据实体,并绑定数据库的表。

@Entity
@Table(name = "player_jpa")
public class PlayerBean {
}

PlayerRepository 通过继承 JpaRepository 接口,由 JpaRepositoryFactoryBean 为其自动注册对应的 Repository Bean。同时,JpaRepository 接口的默认实现类 SimpleJpaRepository 提供了增删改查函数的具体实现。

@Repository
public interface PlayerRepository extends JpaRepository<PlayerBean, Long> {
}

随后,在需要使用 PlayerRepository 的类中,你可以通过 @Autowired 自动装配,这样就可以直接使用增删改查函数了。示例代码如下:

@Autowired
private PlayerRepository playerRepository;

插入或更新数据

playerRepository.save(player);

更多信息参考插入数据更新数据

查询数据

PlayerBean player = playerRepository.findById(id).orElse(null);

更多信息参考查询数据

删除数据

playerRepository.deleteById(id);

更多信息参考删除数据

下一步

需要帮助?