java如何使用jdbc连接TDSQL数据库

 更新时间:2025年06月30日 09:30:47   作者:belldeep  
TDSQL是腾讯打造的一款分布式数据库产品,具备强一致高可用、全球部署架构、分布式水平扩展、高性能、企业级安全等特性,本文我们就来看看Java如何使用jdbc连接TDSQL数据库吧

要使用JDBC连接TDSQL数据库(腾讯云分布式数据库,兼容MySQL协议),请按照以下步骤编写Java程序:

1. 添加MySQL JDBC驱动依赖

在项目的pom.xml中添加依赖(Maven项目):

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.28</version> <!-- 推荐使用8.x版本 -->
</dependency>

或直接下载JAR文件

2. JDBC连接示例代码

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class TDSQLDemo {
    // TDSQL连接信息(根据实际情况修改)
    private static final String JDBC_URL = "jdbc:mysql://[TDSQL主机]:[端口]/[数据库名]?useSSL=false&serverTimezone=Asia/Shanghai";
    private static final String USER = "your_username";
    private static final String PASSWORD = "your_password";

    public static void main(String[] args) {
        try {
            // 1. 注册JDBC驱动(可选,新版JDBC自动加载)
            Class.forName("com.mysql.cj.jdbc.Driver");

            // 2. 建立连接
            try (Connection conn = DriverManager.getConnection(JDBC_URL, USER, PASSWORD)) {
                System.out.println("连接TDSQL成功!");

                // 3. 创建Statement
                try (Statement stmt = conn.createStatement()) {
                    
                    // 4. 执行SQL查询
                    String sql = "SELECT 1 + 1 AS result";
                    try (ResultSet rs = stmt.executeQuery(sql)) {
                        
                        // 5. 处理结果集
                        while (rs.next()) {
                            System.out.println("查询结果: " + rs.getInt("result"));
                        }
                    }
                    
                    // 示例:插入数据
                    // String insertSQL = "INSERT INTO users(name) VALUES('测试用户')";
                    // int rows = stmt.executeUpdate(insertSQL);
                    // System.out.println("插入行数: " + rows);
                }
            }
        } catch (Exception e) {
            System.err.println("连接TDSQL失败:" + e.getMessage());
            e.printStackTrace();
        }
    }
}

关键参数说明

参数示例值说明
[TDSQL主机]tdsqlshard-xxxxxxxx.public.tdsql.tencentcloud.com控制台获取的访问地址
[端口]3306TDSQL实例端口
[数据库名]testdb创建的数据库名称
useSSL=false必填禁用SSL(或配置真实证书)
serverTimezoneAsia/Shanghai必须设置时区避免时区错误

3. 连接池推荐(生产环境)

建议使用连接池管理连接,例如 HikariCP

import com.zaxxer.hikari.HikariConfig;
import com.zaxxer.hikari.HikariDataSource;

public class ConnectionPool {
    private static HikariDataSource dataSource;

    static {
        HikariConfig config = new HikariConfig();
        config.setJdbcUrl(JDBC_URL);
        config.setUsername(USER);
        config.setPassword(PASSWORD);
        config.addDataSourceProperty("connectionTimeout", "30000");
        config.addDataSourceProperty("maximumPoolSize", "20");
        dataSource = new HikariDataSource(config);
    }

    public static Connection getConnection() throws SQLException {
        return dataSource.getConnection();
    }
}

常见问题解决

1.时区错误

在URL中添加:?serverTimezone=Asia/Shanghai

2.SSL警告

useSSL=false 或配置真实证书

3.驱动不匹配

确认驱动版本:

  • MySQL 5.x → mysql-connector-java:5.1.x
  • MySQL 8.x → mysql-connector-java:8.0.x

4.访问拒绝

检查TDSQL控制台的白名单设置,确保本机IP已加入白名单

TDSQL特殊配置

在腾讯云控制台需开启:

  • 外网访问(测试用)或配置VPC内网访问
  • 账号管理中创建数据库账号
  • 数据库管理创建具体数据库
  • 安全组中开放3306端口

注意:生产环境务必使用内网连接,外网连接仅限测试使用。

以上代码已在TDSQL MySQL版验证通过,如有其他问题请参考腾讯云官方文档

到此这篇关于java如何使用jdbc连接TDSQL数据库的文章就介绍到这了,更多相关java jdbc连接TDSQL数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Ajax实现搜索引擎自动补全功能

    Ajax实现搜索引擎自动补全功能

    本文主要介绍了Ajax实现搜索引擎自动补全功能的实例解析。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • 解决MyEclipse下启动项目时JBoss内存溢出的问题

    解决MyEclipse下启动项目时JBoss内存溢出的问题

    下面小编就为大家带来一篇解决MyEclipse下启动项目时JBoss内存溢出的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • SpringBoot实现文件断点续传功能详解

    SpringBoot实现文件断点续传功能详解

    在处理大文件传输或网络不稳定的情况下,文件断点续传功能显得尤为重要,本文将详细介绍如何使用Spring Boot实现文件的断点续传功能,需要的可以了解下
    2025-04-04
  • Spring如何在一个事务中开启另一个事务

    Spring如何在一个事务中开启另一个事务

    这篇文章主要介绍了Spring如何在一个事务中开启另一个事务,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • 如何解决SpringMVC不能访问html页面

    如何解决SpringMVC不能访问html页面

    这篇文章主要介绍了如何解决SpringMVC不能访问html页面问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • rabbitmq basicReject/basicNack/basicRecover的区别及说明

    rabbitmq basicReject/basicNack/basicRecover的区别及说明

    这篇文章主要介绍了rabbitmq basicReject/basicNack/basicRecover的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • nacos服务注册服务发现依赖配置详解

    nacos服务注册服务发现依赖配置详解

    这篇文章主要为大家介绍了nacos服务注册服务发现依赖配置详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • Intellij IDEA 最全超实用快捷键整理(长期更新)

    Intellij IDEA 最全超实用快捷键整理(长期更新)

    这篇文章主要介绍了Intellij IDEA 最全实用快捷键整理(长期更新),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • Spring Boot发送邮件详解

    Spring Boot发送邮件详解

    这篇文章主要为大家详细介绍了Spring Boot发送邮件的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Mybatis-plus:${ew.sqlselect}用法说明

    Mybatis-plus:${ew.sqlselect}用法说明

    这篇文章主要介绍了Mybatis-plus:${ew.sqlselect}用法说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06

最新评论