版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
內(nèi)容大綱什么是數(shù)據(jù)庫連接池為什么要用數(shù)據(jù)庫連接池如何用數(shù)據(jù)庫連接池Tip:使用數(shù)據(jù)庫連接池優(yōu)化程序性能DBdaoservlet用戶3用戶1用戶2用戶nconnection缺點:用戶每次請求都需要向數(shù)據(jù)庫獲得鏈接,而數(shù)據(jù)庫創(chuàng)建連接通常需要消耗相對較大的資源,創(chuàng)建時間也較長。假設(shè)網(wǎng)站一天10萬訪問量,數(shù)據(jù)庫服務(wù)器就需要創(chuàng)建10萬次連接,極大的浪費數(shù)據(jù)庫的資源,并且極易造成數(shù)據(jù)庫服務(wù)器內(nèi)存溢出、拓機(jī)。應(yīng)用程序直接獲取鏈接的缺點Tip:使用數(shù)據(jù)庫連接池優(yōu)化程序性能DBdaoservlet用戶3用戶1用戶2用戶n
connectionconnectionconnectionconnectionconnection連接池用從連接池中獲得的連接與數(shù)據(jù)庫通迅Tip:編寫數(shù)據(jù)庫連接池編寫連接池需實現(xiàn)java.sql.DataSource接口。DataSource接口中定義了兩個重載的getConnection方法:ConnectiongetConnection()ConnectiongetConnection(String
username,String
password)實現(xiàn)DataSource接口,并實現(xiàn)連接池功能的步驟:在DataSource構(gòu)造函數(shù)中批量創(chuàng)建與數(shù)據(jù)庫的連接,并把創(chuàng)建的連接加入LinkedList對象中。實現(xiàn)getConnection方法,讓getConnection方法每次調(diào)用時,從LinkedList中取一個Connection返回給用戶。當(dāng)用戶使用完Connection,調(diào)用Connection.close()方法時,Collection對象應(yīng)保證將自己返回到LinkedList中,而不要把conn還給數(shù)據(jù)庫。Collection保證將自己返回到LinkedList中是此處編程的難點。
Tip:數(shù)據(jù)庫連接池核心代碼使用動態(tài)代理技術(shù)構(gòu)建連接池中的connectionproxyConn=(Connection)Proxy.newProxyInstance(this.getClass() .getClassLoader(),conn.getClass().getInterfaces(), newInvocationHandler(){ //此處為內(nèi)部類,當(dāng)close方法被調(diào)用時將conn還回池中,其它方法直接執(zhí)行 publicObjectinvoke(Objectproxy,Methodmethod, Object[]args)throwsThrowable{ if(method.getName().equals("close")){ pool.addLast(conn); returnnull; } returnmethod.invoke(conn,args); } });Tip:開源數(shù)據(jù)庫連接池現(xiàn)在很多WEB服務(wù)器(Weblogic,WebSphere,Tomcat)都提供了DataSoruce的實現(xiàn),即連接池的實現(xiàn)。通常我們把DataSource的實現(xiàn),按其英文含義稱之為數(shù)據(jù)源,數(shù)據(jù)源中都包含了數(shù)據(jù)庫連接池的實現(xiàn)。也有一些開源組織提供了數(shù)據(jù)源的獨立實現(xiàn):DBCP數(shù)據(jù)庫連接池C3P0數(shù)據(jù)庫連接池實際應(yīng)用時不需要編寫連接數(shù)據(jù)庫代碼,直接從數(shù)據(jù)源獲得數(shù)據(jù)庫的連接。程序員編程時也應(yīng)盡量使用這些數(shù)據(jù)源的實現(xiàn),以提升程序的數(shù)據(jù)庫訪問性能。Tip:DBCP數(shù)據(jù)源DBCP是Apache軟件基金組織下的開源連接池實現(xiàn),使用DBCP數(shù)據(jù)源,應(yīng)用程序應(yīng)在系統(tǒng)中增加如下兩個jar文件:Commons-dbcp.jar:連接池的實現(xiàn)Commons-pool.jar:連接池實現(xiàn)的依賴庫Tomcat的連接池正是采用該連接池來實現(xiàn)的。該數(shù)據(jù)庫連接池既可以與應(yīng)用服務(wù)器整合使用,也可由應(yīng)用程序獨立使用。Tip:DBCP數(shù)據(jù)源使用DBCP示例代碼:static{ InputStreamin=JdbcUtil.class.getClassLoader(). getResourceAsStream("perties"); Propertiesprop=newProperties(); prop.load(in); BasicDataSourceFactoryfactory=newBasicDataSourceFactory(); dataSource=factory.createDataSource(prop);}Tip:
C3P0數(shù)據(jù)源Tip:配置Tomcat數(shù)據(jù)源查看Tomcat文檔,示例代碼:ContextinitCtx=newInitialContext();ContextenvCtx=(Context)initCtx.lookup("java:comp/env");dataSource=(DataSource)envCtx.lookup("jdbc/datasource");<Context><Resourcename="jdbc/datasource"auth="Container"type="javax.sql.DataSource"username="root"password="root"driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://localhost:3306/jdbc"maxActive="8"maxIdle="4"/></Context>特別提醒:此種配置下,驅(qū)動jar文件需放置在tomcat的lib下Tip:JNDI技術(shù)簡介JNDI(JavaNamingandDirectoryInterface),Java命名和目錄接口,它對應(yīng)于J2SE中的javax.naming包,這套API的主要作用在于:它可以把Java對象放在一個容器中(JNDI容器),并為容器中的java對象取一個名稱,以后程序想獲得Java對象,只需通過名稱檢索即可。其核心API為Context,它代表JNDI容器,其lookup方法為檢索容器中對應(yīng)名稱的對象。DataBaseMetaData的使用在企業(yè)開發(fā)中,數(shù)據(jù)遷移是經(jīng)常會遇到的事情,此時,需要搞清楚,源數(shù)據(jù)庫與目的數(shù)據(jù)庫之間表以及表內(nèi)部各列之間的異同。而有些時候,我們拿到的項目文檔,未必能準(zhǔn)確表述各個表的準(zhǔn)確結(jié)構(gòu),即使應(yīng)用建模工具反向?qū)С鑫锢斫Y(jié)構(gòu),但依靠人工比對,也是很困難的一件事情。而此時,如果能“反編譯數(shù)據(jù)庫”,提取表信息以及表內(nèi)部各列的信息,然后通過程序自動進(jìn)行比較,并將比較結(jié)果以報表的形式輸出,那么這個問題就簡單很多了。此間“反編譯數(shù)據(jù)庫”要解決兩個問題,一個是數(shù)據(jù)庫中每個用戶表的名稱是什么,另外一個就是對于規(guī)定的表名稱,其內(nèi)部結(jié)構(gòu)是什么樣的,比如有那些列,每列的數(shù)據(jù)類型,長度等等信息。Tip:元數(shù)據(jù)-DataBaseMetaData元數(shù)據(jù):數(shù)據(jù)庫、表、列的定義信息。對象獲取Connection.getDatabaseMetaData()DataBaseMetaData對象getURL():返回一個String類對象,代表數(shù)據(jù)庫的URL。getUserName():返回連接當(dāng)前數(shù)據(jù)庫管理系統(tǒng)的用戶名。getDatabaseProductName():返回數(shù)據(jù)庫的產(chǎn)品名稱。getDatabaseProductVersion():返回數(shù)據(jù)庫的版本號。getDriverName():返回驅(qū)動驅(qū)動程序的名稱。getDriverVersion():返回驅(qū)動程序的版本號。isReadOnly():返回一個boolean值,指示數(shù)據(jù)庫是否只允許讀操作。Tip:元數(shù)據(jù)-ParameterMetaDataPreparedStatement.getParameterMetaData()獲得代表PreparedStatement元數(shù)據(jù)的ParameterMetaData對象。ParameterMetaData對象getParameterCount()獲得指定參數(shù)的個數(shù)getParameterType(int
param)獲得指定參數(shù)的sql類型Tip:元數(shù)據(jù)-ResultSetMetaDataResultSet.getMetaData()獲得代表ResultSet對象元數(shù)據(jù)的ResultSetMetaData對象。ResultSetMetaData對象getColumnCount()
返回resultset對象的列數(shù)getColumnName(int
column)獲得指定列的名稱
getColumnTypeName(int
column)獲得指定列的類型Tip:使用元數(shù)據(jù)簡化JDBC代碼業(yè)務(wù)背景:系統(tǒng)中所有實體對象都涉及到基本的CRUD操作:所有實體的CUD操作代碼基本相同,僅僅發(fā)送給
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024新版?zhèn)€體勞動協(xié)議樣本版
- 2024監(jiān)理服務(wù)擴(kuò)展合同標(biāo)準(zhǔn)文本一
- 2025年度新能源汽車充電樁采購安裝合同3篇
- 二零二五年科技園區(qū)PPP項目合同第三、四章技術(shù)創(chuàng)新與產(chǎn)業(yè)支持細(xì)則3篇
- 唐山科技職業(yè)技術(shù)學(xué)院《吉他(二)》2023-2024學(xué)年第一學(xué)期期末試卷
- 蘇州農(nóng)業(yè)職業(yè)技術(shù)學(xué)院《美國文學(xué)史與作品選讀》2023-2024學(xué)年第一學(xué)期期末試卷
- 二零二五年度班主任班級管理師徒實踐合作協(xié)議3篇
- 事業(yè)單位專任人員2024河南聘用協(xié)議模板版
- 石家莊城市經(jīng)濟(jì)職業(yè)學(xué)院《制藥工程學(xué)》2023-2024學(xué)年第一學(xué)期期末試卷
- 2025年度玻璃制品出口貿(mào)易合同3篇
- 垃圾焚燒發(fā)電環(huán)保培訓(xùn)
- 北京市朝陽區(qū)2024-2025學(xué)年高一(上)期末化學(xué)試卷(含答案)
- 中醫(yī)基礎(chǔ)學(xué)考試題(附答案)
- 2025貴州建筑安全員B證考試題庫附答案
- 2024年杭州師范大學(xué)附屬醫(yī)院高層次衛(wèi)技人才招聘筆試歷年參考題庫頻考點附帶答案
- 2024-2025學(xué)年八年級歷史上冊期末復(fù)習(xí)課件
- 2025年云南省大理州事業(yè)單位招聘339人歷年高頻重點提升(共500題)附帶答案詳解
- 2024-2025學(xué)年度第一學(xué)期三年級數(shù)學(xué)寒假作業(yè) 有答案
- 大型起重機(jī)械現(xiàn)場管理手冊
- 2024年貴州省公務(wù)員錄用考試《行測》真題及答案解析
- 江蘇省南京市聯(lián)合體2024-2025學(xué)年九年級上學(xué)期期中學(xué)情分析化學(xué)試卷(無答案)
評論
0/150
提交評論