国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

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

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

Nov 23, 2020 pm 03:33 PM
java mysql

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

java連結(jié)mysql有五種方式,分別是:

(學(xué)習(xí)影片分享:java教學(xué)影片

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

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

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ū),否則預(yù)設(shè)是UTC時區(qū),比北京時間晚8小時。

然後將mysql資料庫對應(yīng)的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);

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

將第一種方式中:

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

改為:

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

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

?/*
????????使用反射獲取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";
????????/*
????????注冊驅(qū)動
?????????*/
????????DriverManager.registerDriver(driver);
????????/*
????????獲取連接
?????????*/
????????System.out.println(DriverManager.getConnection(url,user,password));
第四種方式:將載入驅(qū)動的方式隱藏起來

將方式三中

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


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

原始程式碼如下:

????????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設(shè)定檔中


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

設(shè)定檔jdbc.properties如下:

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


1、設(shè)定檔應(yīng)該放在src資料夾下

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

3、如果使用的是mysql8.0以上版本,在設(shè)定url檔案時應(yīng)該在後面加上時區(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");

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

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

java入門教學(xué)

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

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

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(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)

如何在Java的地圖上迭代? 如何在Java的地圖上迭代? Jul 13, 2025 am 02:54 AM

遍歷Java中的Map有三種常用方法:1.使用entrySet同時獲取鍵和值,適用於大多數(shù)場景;2.使用keySet或values分別遍歷鍵或值;3.使用Java8的forEach簡化代碼結(jié)構(gòu)。 entrySet返回包含所有鍵值對的Set集合,每次循環(huán)獲取Map.Entry對象,適合頻繁訪問鍵和值的情況;若只需鍵或值,可分別調(diào)用keySet()或values(),也可在遍歷鍵時通過map.get(key)獲取值;Java8中可通過Lambda表達式使用forEach((key,value)-&gt

Java中的可比較與比較器 Java中的可比較與比較器 Jul 13, 2025 am 02:31 AM

在Java中,Comparable用於類內(nèi)部定義默認排序規(guī)則,Comparator用於外部靈活定義多種排序邏輯。 1.Comparable是類自身實現(xiàn)的接口,通過重寫compareTo()方法定義自然順序,適用於類有固定、最常用的排序方式,如String或Integer。 2.Comparator是外部定義的函數(shù)式接口,通過compare()方法實現(xiàn),適合同一類需要多種排序方式、無法修改類源碼或排序邏輯經(jīng)常變化的情況。兩者區(qū)別在於Comparable只能定義一種排序邏輯且需修改類本身,而Compar

MySQL查詢性能優(yōu)化的策略 MySQL查詢性能優(yōu)化的策略 Jul 13, 2025 am 01:45 AM

MySQL查詢性能優(yōu)化需從核心點入手,包括合理使用索引、優(yōu)化SQL語句、表結(jié)構(gòu)設(shè)計與分區(qū)策略、利用緩存及監(jiān)控工具。 1.合理使用索引:在常用查詢字段上建索引,避免全表掃描,注意組合索引順序,不低選擇性字段加索引,避免冗餘索引。 2.優(yōu)化SQL查詢:避免SELECT*,不在WHERE中用函數(shù),減少子查詢嵌套,優(yōu)化分頁查詢方式。 3.表結(jié)構(gòu)設(shè)計與分區(qū):根據(jù)讀寫場景選擇範式或反範式,選用合適字段類型,定期清理數(shù)據(jù),大表考慮水平分錶或按時間分區(qū)。 4.利用緩存與監(jiān)控:使用Redis緩存減輕數(shù)據(jù)庫壓力,開啟慢查詢

如何處理Java中的字符編碼問題? 如何處理Java中的字符編碼問題? Jul 13, 2025 am 02:46 AM

處理Java中的字符編碼問題,關(guān)鍵是在每一步都明確指定使用的編碼。 1.讀寫文本時始終指定編碼,使用InputStreamReader和OutputStreamWriter並傳入明確的字符集,避免依賴系統(tǒng)默認編碼。 2.在網(wǎng)絡(luò)邊界處理字符串時確保兩端一致,設(shè)置正確的Content-Type頭並用庫顯式指定編碼。 3.謹慎使用String.getBytes()和newString(byte[]),應(yīng)始終手動指定StandardCharsets.UTF_8以避免平臺差異導(dǎo)致的數(shù)據(jù)損壞。總之,通過在每個階段

JavaScript數(shù)據(jù)類型:原始與參考 JavaScript數(shù)據(jù)類型:原始與參考 Jul 13, 2025 am 02:43 AM

JavaScript的數(shù)據(jù)類型分為原始類型和引用類型。原始類型包括string、number、boolean、null、undefined和symbol,其值不可變且賦值時復(fù)制副本,因此互不影響;引用類型如對象、數(shù)組和函數(shù)存儲的是內(nèi)存地址,指向同一對象的變量會相互影響。判斷類型可用typeof和instanceof,但需注意typeofnull的歷史問題。理解這兩類差異有助於編寫更穩(wěn)定可靠的代碼。

Java中的'靜態(tài)”關(guān)鍵字是什麼? Java中的'靜態(tài)”關(guān)鍵字是什麼? Jul 13, 2025 am 02:51 AM

InJava,thestatickeywordmeansamemberbelongstotheclassitself,nottoinstances.Staticvariablesaresharedacrossallinstancesandaccessedwithoutobjectcreation,usefulforglobaltrackingorconstants.Staticmethodsoperateattheclasslevel,cannotaccessnon-staticmembers,

在C中使用std :: Chrono 在C中使用std :: Chrono Jul 15, 2025 am 01:30 AM

std::chrono在C 中用於處理時間,包括獲取當前時間、測量執(zhí)行時間、操作時間點與持續(xù)時間及格式化解析時間。 1.獲取當前時間使用std::chrono::system_clock::now(),可轉(zhuǎn)換為可讀字符串但係統(tǒng)時鐘可能不單調(diào);2.測量執(zhí)行時間應(yīng)使用std::chrono::steady_clock以確保單調(diào)性,並通過duration_cast轉(zhuǎn)換為毫秒、秒等單位;3.時間點(time_point)和持續(xù)時間(duration)可相互操作,但需注意單位兼容性和時鐘紀元(epoch)

Java中的結(jié)構(gòu)化並發(fā)是什麼? Java中的結(jié)構(gòu)化並發(fā)是什麼? Jul 13, 2025 am 02:02 AM

結(jié)構(gòu)化的CurrencyInjavasolvesthecomplexityOfManagingMultipleconCurrentTasksbyGroupingTheminToAsingLeunitForClecleanerHandling.1)ITSImplifiesErrorPropagation,andcellation,andcellation,andcellation,andclelation,and and Coordination,and coordination and coordination,尤其是WhendeAlingWithExectectiensorWaitingForroresults.2)

See all articles