數據庫連接池_第1頁
數據庫連接池_第2頁
數據庫連接池_第3頁
數據庫連接池_第4頁
數據庫連接池_第5頁
已閱讀5頁,還剩12頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

內容大綱什么是數據庫連接池為什么要用數據庫連接池如何用數據庫連接池Tip:使用數據庫連接池優化程序性能DBdaoservlet用戶3用戶1用戶2用戶nconnection缺點:用戶每次請求都需要向數據庫獲得鏈接,而數據庫創建連接通常需要消耗相對較大的資源,創建時間也較長。假設網站一天10萬訪問量,數據庫服務器就需要創建10萬次連接,極大的浪費數據庫的資源,并且極易造成數據庫服務器內存溢出、拓機。應用程序直接獲取鏈接的缺點Tip:使用數據庫連接池優化程序性能DBdaoservlet用戶3用戶1用戶2用戶n

connectionconnectionconnectionconnectionconnection連接池用從連接池中獲得的連接與數據庫通迅Tip:編寫數據庫連接池編寫連接池需實現java.sql.DataSource接口。DataSource接口中定義了兩個重載的getConnection方法:ConnectiongetConnection()ConnectiongetConnection(String

username,String

password)實現DataSource接口,并實現連接池功能的步驟:在DataSource構造函數中批量創建與數據庫的連接,并把創建的連接加入LinkedList對象中。實現getConnection方法,讓getConnection方法每次調用時,從LinkedList中取一個Connection返回給用戶。當用戶使用完Connection,調用Connection.close()方法時,Collection對象應保證將自己返回到LinkedList中,而不要把conn還給數據庫。Collection保證將自己返回到LinkedList中是此處編程的難點。

Tip:數據庫連接池核心代碼使用動態代理技術構建連接池中的connectionproxyConn=(Connection)Proxy.newProxyInstance(this.getClass() .getClassLoader(),conn.getClass().getInterfaces(), newInvocationHandler(){ //此處為內部類,當close方法被調用時將conn還回池中,其它方法直接執行 publicObjectinvoke(Objectproxy,Methodmethod, Object[]args)throwsThrowable{ if(method.getName().equals("close")){ pool.addLast(conn); returnnull; } returnmethod.invoke(conn,args); } });Tip:開源數據庫連接池現在很多WEB服務器(Weblogic,WebSphere,Tomcat)都提供了DataSoruce的實現,即連接池的實現。通常我們把DataSource的實現,按其英文含義稱之為數據源,數據源中都包含了數據庫連接池的實現。也有一些開源組織提供了數據源的獨立實現:DBCP數據庫連接池C3P0數據庫連接池實際應用時不需要編寫連接數據庫代碼,直接從數據源獲得數據庫的連接。程序員編程時也應盡量使用這些數據源的實現,以提升程序的數據庫訪問性能。Tip:DBCP數據源DBCP是Apache軟件基金組織下的開源連接池實現,使用DBCP數據源,應用程序應在系統中增加如下兩個jar文件:Commons-dbcp.jar:連接池的實現Commons-pool.jar:連接池實現的依賴庫Tomcat的連接池正是采用該連接池來實現的。該數據庫連接池既可以與應用服務器整合使用,也可由應用程序獨立使用。Tip:DBCP數據源使用DBCP示例代碼:static{ InputStreamin=JdbcUtil.class.getClassLoader(). getResourceAsStream("perties"); Propertiesprop=newProperties(); prop.load(in); BasicDataSourceFactoryfactory=newBasicDataSourceFactory(); dataSource=factory.createDataSource(prop);}Tip:

C3P0數據源Tip:配置Tomcat數據源查看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>特別提醒:此種配置下,驅動jar文件需放置在tomcat的lib下Tip:JNDI技術簡介JNDI(JavaNamingandDirectoryInterface),Java命名和目錄接口,它對應于J2SE中的javax.naming包,這套API的主要作用在于:它可以把Java對象放在一個容器中(JNDI容器),并為容器中的java對象取一個名稱,以后程序想獲得Java對象,只需通過名稱檢索即可。其核心API為Context,它代表JNDI容器,其lookup方法為檢索容器中對應名稱的對象。DataBaseMetaData的使用在企業開發中,數據遷移是經常會遇到的事情,此時,需要搞清楚,源數據庫與目的數據庫之間表以及表內部各列之間的異同。而有些時候,我們拿到的項目文檔,未必能準確表述各個表的準確結構,即使應用建模工具反向導出物理結構,但依靠人工比對,也是很困難的一件事情。而此時,如果能“反編譯數據庫”,提取表信息以及表內部各列的信息,然后通過程序自動進行比較,并將比較結果以報表的形式輸出,那么這個問題就簡單很多了。此間“反編譯數據庫”要解決兩個問題,一個是數據庫中每個用戶表的名稱是什么,另外一個就是對于規定的表名稱,其內部結構是什么樣的,比如有那些列,每列的數據類型,長度等等信息。Tip:元數據-DataBaseMetaData元數據:數據庫、表、列的定義信息。對象獲取Connection.getDatabaseMetaData()DataBaseMetaData對象getURL():返回一個String類對象,代表數據庫的URL。getUserName():返回連接當前數據庫管理系統的用戶名。getDatabaseProductName():返回數據庫的產品名稱。getDatabaseProductVersion():返回數據庫的版本號。getDriverName():返回驅動驅動程序的名稱。getDriverVersion():返回驅動程序的版本號。isReadOnly():返回一個boolean值,指示數據庫是否只允許讀操作。Tip:元數據-ParameterMetaDataPreparedStatement.getParameterMetaData()獲得代表PreparedStatement元數據的ParameterMetaData對象。ParameterMetaData對象getParameterCount()獲得指定參數的個數getParameterType(int

param)獲得指定參數的sql類型Tip:元數據-ResultSetMetaDataResultSet.getMetaData()獲得代表ResultSet對象元數據的ResultSetMetaData對象。ResultSetMetaData對象getColumnCount()

返回resultset對象的列數getColumnName(int

column)獲得指定列的名稱

getColumnTypeName(int

column)獲得指定列的類型Tip:使用元數據簡化JDBC代碼業務背景:系統中所有實體對象都涉及到基本的CRUD操作:所有實體的CUD操作代碼基本相同,僅僅發送給

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論