




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
精品文檔-下載后可編輯Java訪問SQL數(shù)據(jù)庫的優(yōu)化探討-基礎(chǔ)電子導讀:本文概括了Java連接數(shù)據(jù)庫的主要方法,并對JDBC的特點進行了分析。進而從提高訪問數(shù)據(jù)庫效率的角度,論述了采用數(shù)據(jù)庫連接池技術(shù)、優(yōu)化SQL語句格式和多線程方法等可提高Java訪問數(shù)據(jù)庫效率的方法。
1.概述
在軟件開發(fā)中通常都會涉及到數(shù)據(jù)庫的應用。而數(shù)據(jù)庫的連接則是數(shù)據(jù)庫應用的基礎(chǔ)性工作。在當前主流的編程語言中,Java語言因為其不依賴系統(tǒng)平臺、健壯、安全,編寫便可各處運行的特色,使之成為一種應用越來越廣泛的編程語言。在應用Java技術(shù)訪問數(shù)據(jù)庫時,需要利用Java的數(shù)據(jù)庫訪問技術(shù)來實現(xiàn)。在Java中實現(xiàn)對數(shù)據(jù)庫的訪問時是以JDBC為基礎(chǔ)的,而JDBC則是由Java語言所編寫的一系列的類和接口組成,通過JDBC能夠非常方便的連接任意類型的數(shù)據(jù)庫。
2.JDBC特點分析
Java中的JDBC接口有兩個,一個是位于底層的JDBCDriverAPI,另一個是用于面向程序員的應用程序接口,即ApplicationProgramingInterface.其中JDBCDriverAPI有四種類型:一是JDBC-ODBC橋形式、二是部分Java驅(qū)動程序和本機API的組合形式、三是面向數(shù)據(jù)庫中間件的純Java驅(qū)動程序、四是采用直接面向數(shù)據(jù)庫的純Java驅(qū)動程序。上述四類形式中,JDBC-ODBC橋需要在客戶端安裝必要的ODBC驅(qū)動程序,否則無法讀取ODBC數(shù)據(jù)源。這也是這類方式的主要缺點。采用部分Java驅(qū)動程序和本機API的組合形式時,要求在客戶端使用本地代碼來實現(xiàn)對數(shù)據(jù)庫客戶端的API調(diào)用,從而將JDBCAPI轉(zhuǎn)化成商用數(shù)據(jù)庫提供的API來完成數(shù)據(jù)庫的數(shù)據(jù)的提取和存儲。第三種方式不必考慮Java程序的細節(jié),因這些程序細節(jié)在中間件服務器中是背隱藏了的,因此利用這一特點可以用相同的代碼來訪問不同的數(shù)據(jù)庫。這也是這一訪問方式的優(yōu)點。第四種方式則為直接,不論是客戶端的請求還是程序的執(zhí)行結(jié)果都直接在服務器上直接處理,采用該方式無需像前面兩種方法那樣需要安裝驅(qū)動程序或中介軟件,這也是這種應用方式的主要優(yōu)點。
而JDBCAPI則相對更為的固定,也有四種主要的類型,即:java.sql.DriverManage、java.sql.Connection、java.sql.Statement和java.sql.ResultSet.這四種類型分別執(zhí)行不同的任務,且分工明確,因此再次不多做論述。
以上不同的連接方式和方法在針對不同類型的數(shù)據(jù)庫時效率會存在一定的差異,隨著數(shù)據(jù)庫規(guī)模的加大,傳統(tǒng)的數(shù)據(jù)庫訪問方式已經(jīng)體現(xiàn)出弊端,在本文中將在介紹可提高Java訪問SQL數(shù)據(jù)庫效率運行效率的方法。
3.采用數(shù)據(jù)庫連接池技術(shù)
數(shù)據(jù)庫連接池技術(shù)是在JDBC2.0基礎(chǔ)上提出并逐步完善的。其特點是通過重用一組連接對象,使所有用戶之間共享一組己經(jīng)打開的連接,節(jié)省了建立和釋放數(shù)據(jù)庫連接的時間,從而大幅度的提高Java對數(shù)據(jù)庫的訪問性能。
數(shù)據(jù)庫連接池技術(shù)的基本原理是預先設(shè)計一個“緩沖池”,將各類資源放于該“緩沖池”中,主要是在“緩沖池”中預先存入一定的數(shù)據(jù)連接,在程序運行時再根據(jù)需要來從“緩沖池”中取出各連接中的一個,在對該連接的操作完成后將其重新放回“緩沖池”中。
此時對各連接的管理都由“緩沖池”來負責管理。通過連接池的方式,能夠?qū)⒑芏喙ぷ鞫荚凇熬彌_池”的范圍內(nèi)完成,并可通過對連接的控制和管理機制來提高運行效率。
在使用連接池技術(shù)時的關(guān)鍵問題是如何建立連接池以及對連接池中的各類連接的有效管理,這兩部分內(nèi)容也是研究連接池技術(shù)時的重要方向。一般而言,在建立連接池時,應在系統(tǒng)的初始化階段通過讀取XML文件中的特定配置參數(shù)來完成,從而可在內(nèi)存中建立對于應用程序來講是的且配置參數(shù)也是確定的靜態(tài)連接池。當完成連接池的建立后,需其保持穩(wěn)定性,從而讓其他線程能夠在連接池中獲取所需的連接。這種穩(wěn)定性能夠避免建立連接和關(guān)閉連接時的內(nèi)存開銷,從而提高內(nèi)存的使用效率。
在建立起連接池后,更為重要的是對連接的有效管理,如果連接池中的連接管理混亂,反而會適得其反。不同的管理方式的處理效率有一定差異,在針對特定的問題時應當考慮設(shè)計出的管理方式,因此連接池的分配和釋放并沒有所謂的方法,在實踐中,“ReferenceCounting”是一種是用較多的方式。
4.優(yōu)化SQL語句格式
在利用Java訪問數(shù)據(jù)庫時,SQL語句的格式也會對訪問效率造成影響。在實際應用中,常采用Statement對象來執(zhí)行SQL語句。這種方式意味著每次都需要對數(shù)據(jù)庫進行解析編譯。
這無疑會降低對數(shù)據(jù)庫的訪問效率。如果采用PreParedStetment對象來執(zhí)行SQL語句,則會是另外一種情形。當使用PreParedStetment時,按照相應機制,其命令會被數(shù)據(jù)庫引擎解析編譯,并存放于命令緩沖區(qū)內(nèi)。采用Statement和PreParedStetment的主要區(qū)別是后者只需再次解析即可,而無需再次編譯。因此在處理大量重復執(zhí)行的SQL命令語句時,采用PreParedStetment對象將大大提高數(shù)據(jù)庫的運行效率,因避免了大量的重復編譯。
此外,使用PreParedStetment對象的另一個好處是可以配合使用數(shù)據(jù)庫批量更新機制來提高數(shù)據(jù)庫的運行效率。即通過通過調(diào)用整批的更新命令來完成對數(shù)據(jù)庫的所有更新。在應用時,利用PreParedStetment對象執(zhí)行速度由于Statement對象的特點,將PreParedStetment替代Statement對象。
當然,一些基本的操作,如完成對數(shù)據(jù)庫和驅(qū)動配置是否支持批量更新的檢查也是必須的,可利用DatabaseMetaData對象中所提供的SupportBatchUPdates()方法。
5.使用Java多線程技術(shù)
多線程技術(shù)的優(yōu)勢已經(jīng)無需贅述,但在使用多線程技術(shù)時為保證線程間的同步和彼此通信和協(xié)調(diào),因此同步機制顯得尤為重要。
在Java中已經(jīng)提供了幾類可供直接使用的方法來實現(xiàn)線程間的同步。在劃分臨界資源時可借助synchronized這一關(guān)鍵字來對語句塊進行標示,其他Object類中的方法(如wait(),notify()等)以及Tread類中的方法(sleep()、suspend()等)也能夠被直接用來處理不同線程的啟用或中斷操作。采用多線程技術(shù)來提高數(shù)據(jù)庫的訪問效率時關(guān)鍵問題并不在于技術(shù)本身,而是對線程的有效管理,這取決于程序設(shè)計者的控制能力。
6.結(jié)語
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 渝中區(qū)危險化品運輸合同6篇
- 2024屆高考語文專題復習彈琴三境界 寫作指導
- 餐廳窗口承包合同
- 2025年青海道路運輸從業(yè)人員資格考試內(nèi)容有哪些
- 公司和個人勞務合同
- 學校食堂檔口承包合同
- 會議邀請函模板表
- 公司財務管理規(guī)章制度的修訂與完善建議
- 企業(yè)高管聘用合同
- 農(nóng)田租地合同協(xié)議書
- 2025年湖南科技職業(yè)學院高職單招職業(yè)技能測試近5年??及鎱⒖碱}庫含答案解析
- (正式版)SH∕T 3548-2024 石油化工涂料防腐蝕工程施工及驗收規(guī)范
- 教學課件-古文陋室銘劉禹錫課件
- 主題班會教學課件:禁毒教育主題班會(共38張)
- 道路、橋梁、隧道、地鐵施工標準化手冊(專業(yè)篇)
- 初中人音版音樂七年級下冊.第二單元長江之歌.(14張)ppt課件
- NancyDrew分析
- 離心式排風機安裝施工方案及技術(shù)措施
- 中西紀年對照表
- 粵勞社[2002]246號關(guān)于職工在機關(guān)事業(yè)單位與企業(yè)之間流動時社會保險關(guān)系處理意見的通知
- 通信防雷與接地系統(tǒng)PPT學習教案
評論
0/150
提交評論