欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java如何使用jdbc連接TDSQL數(shù)據(jù)庫

 更新時間:2025年06月30日 09:30:47   作者:belldeep  
TDSQL是騰訊打造的一款分布式數(shù)據(jù)庫產(chǎn)品,具備強(qiáng)一致高可用、全球部署架構(gòu)、分布式水平擴(kuò)展、高性能、企業(yè)級安全等特性,本文我們就來看看Java如何使用jdbc連接TDSQL數(shù)據(jù)庫吧

要使用JDBC連接TDSQL數(shù)據(jù)庫(騰訊云分布式數(shù)據(jù)庫,兼容MySQL協(xié)議),請按照以下步驟編寫Java程序:

1. 添加MySQL JDBC驅(qū)動依賴

在項目的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連接信息(根據(jù)實際情況修改)
    private static final String JDBC_URL = "jdbc:mysql://[TDSQL主機(jī)]:[端口]/[數(shù)據(jù)庫名]?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驅(qū)動(可選,新版JDBC自動加載)
            Class.forName("com.mysql.cj.jdbc.Driver");

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

                // 3. 創(chuàng)建Statement
                try (Statement stmt = conn.createStatement()) {
                    
                    // 4. 執(zhí)行SQL查詢
                    String sql = "SELECT 1 + 1 AS result";
                    try (ResultSet rs = stmt.executeQuery(sql)) {
                        
                        // 5. 處理結(jié)果集
                        while (rs.next()) {
                            System.out.println("查詢結(jié)果: " + rs.getInt("result"));
                        }
                    }
                    
                    // 示例:插入數(shù)據(jù)
                    // String insertSQL = "INSERT INTO users(name) VALUES('測試用戶')";
                    // int rows = stmt.executeUpdate(insertSQL);
                    // System.out.println("插入行數(shù): " + rows);
                }
            }
        } catch (Exception e) {
            System.err.println("連接TDSQL失?。? + e.getMessage());
            e.printStackTrace();
        }
    }
}

關(guān)鍵參數(shù)說明

參數(shù)示例值說明
[TDSQL主機(jī)]tdsqlshard-xxxxxxxx.public.tdsql.tencentcloud.com控制臺獲取的訪問地址
[端口]3306TDSQL實例端口
[數(shù)據(jù)庫名]testdb創(chuàng)建的數(shù)據(jù)庫名稱
useSSL=false必填禁用SSL(或配置真實證書)
serverTimezoneAsia/Shanghai必須設(shè)置時區(qū)避免時區(qū)錯誤

3. 連接池推薦(生產(chǎn)環(huán)境)

建議使用連接池管理連接,例如 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.時區(qū)錯誤

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

2.SSL警告

useSSL=false 或配置真實證書

3.驅(qū)動不匹配

確認(rèn)驅(qū)動版本:

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

4.訪問拒絕

檢查TDSQL控制臺的白名單設(shè)置,確保本機(jī)IP已加入白名單

TDSQL特殊配置

在騰訊云控制臺需開啟:

  • 外網(wǎng)訪問(測試用)或配置VPC內(nèi)網(wǎng)訪問
  • 賬號管理中創(chuàng)建數(shù)據(jù)庫賬號
  • 數(shù)據(jù)庫管理創(chuàng)建具體數(shù)據(jù)庫
  • 安全組中開放3306端口

注意:生產(chǎn)環(huán)境務(wù)必使用內(nèi)網(wǎng)連接,外網(wǎng)連接僅限測試使用。

以上代碼已在TDSQL MySQL版驗證通過,如有其他問題請參考騰訊云官方文檔

到此這篇關(guān)于java如何使用jdbc連接TDSQL數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)java jdbc連接TDSQL數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java的Hibernate框架中的基本映射用法講解

    Java的Hibernate框架中的基本映射用法講解

    映射是Hibernate框架操作數(shù)據(jù)庫數(shù)據(jù)的重要特性之一,這里我們來看一下Java的Hibernate框架中的基本映射用法講解,包括最基本的單向一對一與多對一映射關(guān)系等:
    2016-07-07
  • SpringBoot中的main方法注入service

    SpringBoot中的main方法注入service

    這篇文章主要介紹了SpringBoot中的main方法注入service操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • java8升級java21方法步驟(完整pom文件升級及代碼修改)

    java8升級java21方法步驟(完整pom文件升級及代碼修改)

    在從Java?8升級至Java?211的過程中,需要對多個POM文件進(jìn)行升級,涉及parent、web、service等模塊,文中通過代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用java具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-11-11
  • Java判斷范圍型的數(shù)據(jù)是否存在重疊的方法

    Java判斷范圍型的數(shù)據(jù)是否存在重疊的方法

    遇到了個問題,同一天可以輸入多個時間段,但是每個時間段的時間不能出現(xiàn)重疊,這不就是判斷數(shù)據(jù)返回是否有重疊的變種嗎,所以本文給大家介紹了Java判斷范圍型的數(shù)據(jù)是否存在重疊的方法,需要的朋友可以參考下
    2024-07-07
  • 通過代碼實例深入解析Java重寫和重載

    通過代碼實例深入解析Java重寫和重載

    這篇文章主要介紹了通過代碼實例深入解析Java重寫和重載,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • java使用MulticastSocket實現(xiàn)基于廣播的多人聊天室

    java使用MulticastSocket實現(xiàn)基于廣播的多人聊天室

    這篇文章主要為大家詳細(xì)介紹了java使用MulticastSocket實現(xiàn)基于廣播的多人聊天室,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • java實現(xiàn)哈弗曼編碼與反編碼實例分享(哈弗曼算法)

    java實現(xiàn)哈弗曼編碼與反編碼實例分享(哈弗曼算法)

    本文介紹java實現(xiàn)哈弗曼編碼與反編碼實例,大家參考使用吧
    2014-01-01
  • Mybatis批量刪除多表

    Mybatis批量刪除多表

    MyBatis的作用我想不用多說,今天說說MyBatis中的批量刪除操作。 需要的朋友一起看看吧
    2017-10-10
  • SpringAOP中的切點表達(dá)式Pointcut詳解

    SpringAOP中的切點表達(dá)式Pointcut詳解

    這篇文章主要介紹了SpringAOP中的切點表達(dá)式Pointcut詳解,Spring?的?AOP?中的一個核心概念是切點(Pointcut),切點表達(dá)式定義通知(Advice)執(zhí)行的范圍,需要的朋友可以參考下
    2023-08-08
  • SpringBoot中間件封裝限流器的方案詳解

    SpringBoot中間件封裝限流器的方案詳解

    這篇文章主要介紹了SpringBoot中間件封裝限流器,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07

最新評論