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 | 控制臺獲取的訪問地址 |
| [端口] | 3306 | TDSQL實例端口 |
| [數(shù)據(jù)庫名] | testdb | 創(chuàng)建的數(shù)據(jù)庫名稱 |
| useSSL=false | 必填 | 禁用SSL(或配置真實證書) |
| serverTimezone | Asia/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)文章
java8升級java21方法步驟(完整pom文件升級及代碼修改)
在從Java?8升級至Java?211的過程中,需要對多個POM文件進(jìn)行升級,涉及parent、web、service等模塊,文中通過代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用java具有一定的參考借鑒價值,需要的朋友可以參考下2024-11-11
Java判斷范圍型的數(shù)據(jù)是否存在重疊的方法
遇到了個問題,同一天可以輸入多個時間段,但是每個時間段的時間不能出現(xiàn)重疊,這不就是判斷數(shù)據(jù)返回是否有重疊的變種嗎,所以本文給大家介紹了Java判斷范圍型的數(shù)據(jù)是否存在重疊的方法,需要的朋友可以參考下2024-07-07
java使用MulticastSocket實現(xiàn)基于廣播的多人聊天室
這篇文章主要為大家詳細(xì)介紹了java使用MulticastSocket實現(xiàn)基于廣播的多人聊天室,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01
java實現(xiàn)哈弗曼編碼與反編碼實例分享(哈弗曼算法)
本文介紹java實現(xiàn)哈弗曼編碼與反編碼實例,大家參考使用吧2014-01-01
SpringAOP中的切點表達(dá)式Pointcut詳解
這篇文章主要介紹了SpringAOP中的切點表達(dá)式Pointcut詳解,Spring?的?AOP?中的一個核心概念是切點(Pointcut),切點表達(dá)式定義通知(Advice)執(zhí)行的范圍,需要的朋友可以參考下2023-08-08

