亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁 Java Java入門 java有幾種連接mysql的方式?分別是什麼?

java有幾種連接mysql的方式?分別是什麼?

Nov 23, 2020 pm 03:33 PM
java mysql

java有幾種連接mysql的方式?分別是什麼?

java連結mysql有五種方式,分別是:

(學習影片分享:java教學影片

第一種方式:將使用者名稱和密碼封裝在Properties類別中

首先,匯入資料庫連線包這個是毋庸置疑的。建立一個jdbc驅動dirver。將資料庫(以MySQL為例)的url保存在所建立的字串url中。如果mysql版本低於8.0,則url儲存形式應該為:

String?url?=?"jdbc:mysql://localhost:3306/test"

如果mysql版本為8.0版本或以上,url儲存形式為:

String?url?=?"jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai";

這裡使用的mysql版本是8.0,所以後面加上了時區(qū),否則預設是UTC時區(qū),比北京時間晚8小時。

然後將mysql資料庫對應的user和password封裝在Properties類別中,最後透過Connection類別來建立資料庫連接,原始碼如下:

		Driver?driver?=?new?com.mysql.jdbc.Driver();
????????String?url?=?"jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai";
????????/*
????????將用戶名和密碼封裝在Properties中
?????????*/
????????Properties?info?=?new?Properties();
????????info.setProperty("user","root");
????????info.setProperty("password","ab20010322");

????????Connection?conn?=?driver.connect(url,info);

????????System.out.println(conn);

第二種方式:在方式一的基礎上,利用反射實現(xiàn)驅動

將第一種方式中:

Driver?driver?=?new?com.mysql.jdbc.Driver();

改為:

Class?clazz?=?Class.forName("com.mysql.jdbc.Driver");
Driver?driver?=?(Driver)?clazz.newInstance();

相對於第一種方式,兩種實現(xiàn)的功能相同,但是第二種方式利用反射來實現(xiàn)驅動,這樣可以避免使用第三方接口,使得程式碼有更好的可移植性。第二種方式原始碼如下:

?/*
????????使用反射獲取Driver類實例
????????與Driver?driver?=?new?com.mysql.jdbc.Driver()功能相同,只是不適用第三方接口,使得程序具有更好的可移植性
?????????*/
????????Class?clazz?=?Class.forName("com.mysql.jdbc.Driver");
????????Driver?driver?=?(Driver)?clazz.newInstance();

????????/*
????????提供要連接的數(shù)據(jù)庫
?????????*/
????????String?url?=?"jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai";

????????/*
????????提供需要的用戶名和密碼
?????????*/
????????Properties?info?=?new?Properties();
????????info.setProperty("user","root");
????????info.setProperty("password","ab20010322");

????????Connection?connection?=?driver.connect(url,info);

????????System.out.println(connection);

第三種方式:使用DriveManager(classs)取代Drive

##原始程式碼如下:

????????Class?clazz?=?Class.forName("com.mysql.jdbc.Driver");
????????Driver?driver?=?(Driver)?clazz.newInstance();
????????/*
????????提供連接信息
?????????*/
????????String?url?=?"jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai";
????????String?user?=?"root";
????????String?password?=?"ab20010322";
????????/*
????????注冊驅動
?????????*/
????????DriverManager.registerDriver(driver);
????????/*
????????獲取連接
?????????*/
????????System.out.println(DriverManager.getConnection(url,user,password));
第四種方式:將載入驅動的方式隱藏起來

將方式三中

Driver?driver?=?(Driver)?clazz.newInstance();
DriverManager.registerDriver(driver);
改為


Class.forName("com.mysql.jdbc.Driver");
這種方式,可以將驅動程式載入情況隱藏

原始程式碼如下:

????????String?url?=?"jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai";
????????String?user?=?"root";
????????String?password?=?"ab20010322";
????????/*
????????加載Driver
?????????*/
????????Class.forName("com.mysql.jdbc.Driver");//????????Driver?driver?=?(Driver)?clazz.newInstance();//????????DriverManager.registerDriver(driver);
????????/*
????????獲取連接
?????????*/
????????System.out.println(DriverManager.getConnection(url,user,password));
方式五:將資料庫所需的基本資訊放在jdbc.properties設定檔中


對於上面四種連接方式,都將資料庫資訊裸露出來。這樣做是不安全的。對此,我們應該將資料庫所需的基本資訊放在jdbc.properties設定檔中,再透過InputStream讀取出來。這是安全的也是我們最常用的資料庫連接方式

設定檔jdbc.properties如下:

user=root
password=123456url=jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
Driver=com.mysql.cj.jdbc.Driver
注意:


1、設定檔應該放在src資料夾下

2、user和password使用自己的資料庫使用者名稱和密碼

3、如果使用的是mysql8.0以上版本,在設定url檔案時應該在後面加上時區(qū),否則會報錯誤

原始程式碼如下:

????????InputStream?inputStream?=?ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
????????Properties?info?=?new?Properties();
????????info.load(inputStream);
????????
????????String?user?=??info.getProperty("user");
????????String?password?=?info.getProperty("password");
????????String?url?=?info.getProperty("url");
????????String?driver?=?info.getProperty("Driver");

????????/*
????????加載驅動
?????????*/
????????Class.forName(driver);

????????/*
????????獲取連接
?????????*/
????????Connection?conn?=?DriverManager.getConnection(url,user,password);
????????System.out.println(conn);
相關推薦:

java入門教學

以上是java有幾種連接mysql的方式?分別是什麼?的詳細內(nèi)容。更多資訊請關注PHP中文網(wǎng)其他相關文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權的內(nèi)容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
VSCODE設置。 JSON位置 VSCODE設置。 JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位於用戶級或工作區(qū)級路徑,用於自定義VSCode設置。 1.用戶級路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級路徑:項目根目錄下的.vscode/settings

如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務,必須先關閉自動提交模式,再執(zhí)行多個操作,最後根據(jù)結果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務;2.執(zhí)行多個SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時應使用try-with-resources管理資源,妥善處理異常並關閉連接,避免連接洩漏;此外建議使用連接池、設置保存點實現(xiàn)部分回滾,並保持事務盡可能短以提升性能。

在Java的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

了解Java虛擬機(JVM)內(nèi)部 了解Java虛擬機(JVM)內(nèi)部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當前日期時間;3.使用of()方法創(chuàng)建特定日期時間;4.利用plus/minus方法不可變地增減時間;5.使用ZonedDateTime和ZoneId處理時區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

Google Chrome無法打開本地文件 Google Chrome無法打開本地文件 Aug 01, 2025 am 05:24 AM

ChromecanopenlocalfileslikeHTMLandPDFsbyusing"Openfile"ordraggingthemintothebrowser;ensuretheaddressstartswithfile:///;2.SecurityrestrictionsblockAJAX,localStorage,andcross-folderaccessonfile://;usealocalserverlikepython-mhttp.server8000tor

了解網(wǎng)絡端口和防火牆 了解網(wǎng)絡端口和防火牆 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

實施MySQL數(shù)據(jù)譜系跟蹤 實施MySQL數(shù)據(jù)譜系跟蹤 Aug 02, 2025 pm 12:37 PM

實現(xiàn)MySQL數(shù)據(jù)血緣追蹤的核心方法包括:1.利用Binlog記錄數(shù)據(jù)變更來源,開啟並解析binlog,結合應用層上下文追溯具體業(yè)務動作;2.在ETL流程中註入血緣標籤,通過工具同步時記錄源與目標的映射關係;3.給數(shù)據(jù)加註釋和元數(shù)據(jù)標籤,在建表時說明字段來源,並接入元數(shù)據(jù)管理系統(tǒng)形成可視化圖譜;4.注意主鍵一致性、避免過度依賴SQL解析、版本控制數(shù)據(jù)模型變化及定期校驗血緣數(shù)據(jù),確保血緣追蹤準確可靠。

See all articles