




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、北京傳智播客教育 JDBC開發(fā)王昭珽北京傳智播客教育 Tip:使用數(shù)據(jù)庫連接池優(yōu)化程序性能DBDaoservlet用戶3用戶1用戶2用戶nconnection缺點(diǎn):用戶每次請(qǐng)求都需要向數(shù)據(jù)庫獲得鏈接,而數(shù)據(jù)庫創(chuàng)建連接通常需要消耗相對(duì)較大的資源,創(chuàng)建時(shí)間也較長。假設(shè)網(wǎng)站一天10萬訪問量,數(shù)據(jù)庫服務(wù)器就需要?jiǎng)?chuàng)建10萬次連接,極大的浪費(fèi)數(shù)據(jù)庫的資源,并且極易造成數(shù)據(jù)庫服務(wù)器內(nèi)存溢出、拓機(jī)。應(yīng)用程序直接獲取鏈接的缺點(diǎn)北京傳智播客教育 Tip:使用數(shù)據(jù)庫連接池優(yōu)化程序性能DBDaoservlet用戶3用戶1用戶2用戶n connectionconnectionconnectionconnectionco
2、nnection連接池用從連接池中獲得的連接與數(shù)據(jù)庫通迅北京傳智播客教育 編寫一個(gè)基本的連接池實(shí)現(xiàn)連接復(fù)用北京傳智播客教育 Tip:編寫數(shù)據(jù)庫連接池編寫連接池需實(shí)現(xiàn)javax.sql.DataSource接口。DataSource接口中定義了兩個(gè)重載的getConnection方法:Connection getConnection() Connection getConnection(Stringusername, Stringpassword) 實(shí)現(xiàn)DataSource接口,并實(shí)現(xiàn)連接池功能的步驟:在DataSource構(gòu)造函數(shù)中批量創(chuàng)建與數(shù)據(jù)庫的連接,并把創(chuàng)建的連接加入LinkedList
3、對(duì)象中。實(shí)現(xiàn)getConnection方法,讓getConnection方法每次調(diào)用時(shí),從LinkedList中取一個(gè)Connection返回給用戶。當(dāng)用戶使用完Connection,調(diào)用Connection.close()方法時(shí),Collection對(duì)象應(yīng)保證將自己返回到LinkedList中,而不要把conn還給數(shù)據(jù)庫。Collection保證將自己返回到LinkedList中是此處編程的難點(diǎn)。 北京傳智播客教育 Tip:數(shù)據(jù)庫連接池核心代碼使用動(dòng)態(tài)代理技術(shù)構(gòu)建連接池中的connectionproxyConn = (Connection) Proxy.newProxyInstance(th
4、is.getClass().getClassLoader(), conn.getClass().getInterfaces(),new InvocationHandler() /此處為內(nèi)部類,當(dāng)close方法被調(diào)用時(shí)將conn還回池中,其它方法直接執(zhí)行public Object invoke(Object proxy, Method method, Object args) throws Throwable if (method.getName().equals(close) pool.addLast(conn);return null;return method.invoke(conn, a
5、rgs););北京傳智播客教育 Tip:開源數(shù)據(jù)庫連接池現(xiàn)在很多WEB服務(wù)器(Weblogic, WebSphere, Tomcat)都提供了DataSoruce的實(shí)現(xiàn),即連接池的實(shí)現(xiàn)。通常我們把DataSource的實(shí)現(xiàn),按其英文含義稱之為數(shù)據(jù)源,數(shù)據(jù)源中都包含了數(shù)據(jù)庫連接池的實(shí)現(xiàn)。也有一些開源組織提供了數(shù)據(jù)源的獨(dú)立實(shí)現(xiàn):DBCP 數(shù)據(jù)庫連接池 C3P0 數(shù)據(jù)庫連接池實(shí)際應(yīng)用時(shí)不需要編寫連接數(shù)據(jù)庫代碼,直接從數(shù)據(jù)源獲得數(shù)據(jù)庫的連接。程序員編程時(shí)也應(yīng)盡量使用這些數(shù)據(jù)源的實(shí)現(xiàn),以提升程序的數(shù)據(jù)庫訪問性能。北京傳智播客教育 Tip:DBCP數(shù)據(jù)源DBCP 是 Apache 軟件基金組織下的開源連接
6、池實(shí)現(xiàn),使用DBCP數(shù)據(jù)源,應(yīng)用程序應(yīng)在系統(tǒng)中增加如下兩個(gè) jar 文件:Commons-dbcp.jar:連接池的實(shí)現(xiàn)Commons-pool.jar:連接池實(shí)現(xiàn)的依賴庫Tomcat 的連接池正是采用該連接池來實(shí)現(xiàn)的。該數(shù)據(jù)庫連接池既可以與應(yīng)用服務(wù)器整合使用,也可由應(yīng)用程序獨(dú)立使用。北京傳智播客教育 Tip:DBCP數(shù)據(jù)源使用DBCP示例代碼:staticInputStream in = JdbcUtil.class.getClassLoader().getResourceAsStream(perties);Properties prop = new Proper
7、ties();prop.load(in);BasicDataSourceFactory factory = new BasicDataSourceFactory();dataSource = factory.createDataSource(prop);北京傳智播客教育 Tip: C3P0 數(shù)據(jù)源北京傳智播客教育 Tip:配置Tomcat數(shù)據(jù)源查看Tomcat文檔,示例代碼:在Servlet中打印一下:Context initCtx = new InitialContext();Context envCtx = (Context) initCtx.lookup( p/env);dataSour
8、ce = (DataSource)envCtx.lookup(jdbc/datasource); 特別提醒:此種配置下,驅(qū)動(dòng)jar文件需放置在tomcat的lib下北京傳智播客教育 Tip:JNDI技術(shù)簡介JNDI(Java Naming and Directory Interface),Java命名和目錄接口,它對(duì)應(yīng)于J2SE中的javax.naming包,這套API的主要作用在于:它可以把Java對(duì)象放在一個(gè)容器中(JNDI容器),并為容器中的java對(duì)象取一個(gè)名稱,以后程序想獲得Java對(duì)象,只需通過名稱檢索即可。其核心API為Context,它代表JNDI容器,其lookup方法為檢索
9、容器中對(duì)應(yīng)名稱的對(duì)象。北京傳智播客教育 編寫自己的JDBC框架北京傳智播客教育 Tip:元數(shù)據(jù) DataBaseMetaData元數(shù)據(jù):數(shù)據(jù)庫、表、列的定義信息。Connection.getMetaData()DataBaseMetaData對(duì)象getURL():返回一個(gè)String類對(duì)象,代表數(shù)據(jù)庫的URL。getUserName():返回連接當(dāng)前數(shù)據(jù)庫管理系統(tǒng)的用戶名。getDatabaseProductName():返回?cái)?shù)據(jù)庫的產(chǎn)品名稱。getDatabaseProductVersion():返回?cái)?shù)據(jù)庫的版本號(hào)。getDriverName():返回驅(qū)動(dòng)驅(qū)動(dòng)程序的名稱。getDriverV
10、ersion():返回驅(qū)動(dòng)程序的版本號(hào)。isReadOnly():返回一個(gè)boolean值,指示數(shù)據(jù)庫是否只允許讀操作。北京傳智播客教育 Tip:元數(shù)據(jù) ParameterMetaData PreparedStatement . getParameterMetaData() 獲得代表PreparedStatement元數(shù)據(jù)的ParameterMetaData對(duì)象。 Select * from user where name=? And password=?ParameterMetaData對(duì)象getParameterCount() 獲得指定參數(shù)的個(gè)數(shù)getParameterType(intpa
11、ram) 獲得指定參數(shù)的sql類型(驅(qū)動(dòng)可能不支持)北京傳智播客教育 Tip:元數(shù)據(jù) ResultSetMetaData ResultSet. getMetaData() 獲得代表ResultSet對(duì)象元數(shù)據(jù)的ResultSetMetaData對(duì)象。 ResultSetMetaData對(duì)象getColumnCount() 返回resultset對(duì)象的列數(shù)getColumnName(intcolumn) 獲得指定列的名稱getColumnTypeName(intcolumn)獲得指定列的類型 java.sql.Types北京傳智播客教育 Tip:使用元數(shù)據(jù)簡化JDBC代碼業(yè)務(wù)背景:系統(tǒng)中所有實(shí)體
12、對(duì)象都涉及到基本的CRUD操作:所有實(shí)體的CUD操作代碼基本相同,僅僅發(fā)送給數(shù)據(jù)庫的SQL語句不同而已,因此可以把CUD操作的所有相同代碼抽取到工具類的一個(gè)update方法中,并定義參數(shù)接收變化的SQL語句。實(shí)體的R操作,除SQL語句不同之外,根據(jù)操作的實(shí)體不同,對(duì)ResultSet的映射也各不相同,因此可義一個(gè)query方法,除以參數(shù)形式接收變化的SQL語句外,可以使用策略模式由qurey方法的調(diào)用者決定如何把ResultSet中的數(shù)據(jù)映射到實(shí)體對(duì)象中。(Bean,BeanList,Long)練習(xí):利用自己的框架更改原有項(xiàng)目String columnName = md.getColumnNa
13、me(i);Object columnData = rs.getObject(i);Field feild = clazz.getDeclaredField(columnName);feild.setAccessible(true);feild.set(obj, columnData);北京傳智播客教育 Tip:O-R Mapping簡介什么是O-R Mapping常用O-R Mapping映射工具Hibernate CMP JPA(Java Persistent API)IbatisCommons DbUtils(只是對(duì)JDBC簡單封裝)Spring JDBC Template北京傳智播客教
14、育 ApacheDBUtils框架北京傳智播客教育 簡介commons-dbutils 是 Apache 組織提供的一個(gè)開源 JDBC工具類庫,它是對(duì)JDBC的簡單封裝,學(xué)習(xí)成本極低,并且使用dbutils能極大簡化jdbc編碼的工作量,同時(shí)也不會(huì)影響程序的性能。因此dbutils成為很多不喜歡hibernate的公司的首選。API介紹(查看QueryRunner的API) mons.dbutils.QueryRunner :DBAssist mons.dbutils.ResultSetHandler工具類 mons.dbutils.DbUtils、。 北京傳智播客教育 DbUtils類 Db
15、Utils :提供如關(guān)閉連接、裝載JDBC驅(qū)動(dòng)程序等常規(guī)工作的工具類,里面的所有方法都是靜態(tài)的。主要方法如下:public static void close() throws java.sql.SQLException:DbUtils類提供了三個(gè)重載的關(guān)閉方法。這些方法檢查所提供的參數(shù)是不是NULL,如果不是的話,它們就關(guān)閉Connection、Statement和ResultSet。public static void closeQuietly(): 這一類方法不僅能在Connection、Statement和ResultSet為NULL情況下避免關(guān)閉,還能隱藏一些在程序中拋出的SQLEe
16、ception。public static void commitAndCloseQuietly(Connection conn): 用來提交連接,然后關(guān)閉連接,并且在關(guān)閉連接時(shí)不拋出SQL異常。 public static boolean loadDriver(java.lang.String driverClassName):這一方裝載并注冊(cè)JDBC驅(qū)動(dòng)程序,如果成功就返回true。使用該方法,你不需要捕捉這個(gè)異常ClassNotFoundException。北京傳智播客教育 QueryRunner類 該類簡單化了SQL查詢,它與ResultSetHandler組合在一起使用可以完成大部分
17、的數(shù)據(jù)庫操作,能夠大大減少編碼量。QueryRunner類提供了兩個(gè)構(gòu)造方法:默認(rèn)的構(gòu)造方法需要一個(gè) javax.sql.DataSource 來作參數(shù)的構(gòu)造方法。大文本操作北京傳智播客教育 QueryRunner類的主要方法public Object query(Connection conn, String sql, Object params, ResultSetHandler rsh) throws SQLException:執(zhí)行一個(gè)查詢操作,在這個(gè)查詢中,對(duì)象數(shù)組中的每個(gè)元素值被用來作為查詢語句的置換參數(shù)。該方法會(huì)自行處理 PreparedStatement 和 ResultSet
18、的創(chuàng)建和關(guān)閉。public Object query(String sql, Object params, ResultSetHandler rsh) throws SQLException:幾乎與第一種方法一樣;唯一的不同在于它不將數(shù)據(jù)庫連接提供給方法,并且它是從提供給構(gòu)造方法的數(shù)據(jù)源(DataSource) 或使用的setDataSource 方法中重新獲得 Connection。public Object query(Connection conn, String sql, ResultSetHandler rsh) throws SQLException : 執(zhí)行一個(gè)不需要置換參數(shù)的查
19、詢操作。public int update(Connection conn, String sql, Object params) throws SQLException:用來執(zhí)行一個(gè)更新(插入、更新或刪除)操作。public int update(Connection conn, String sql) throws SQLException:用來執(zhí)行一個(gè)不需要置換參數(shù)的更新操作。北京傳智播客教育 ResultSetHandler接口 該接口用于處理 java.sql.ResultSet,將數(shù)據(jù)按要求轉(zhuǎn)換為另一種形式。ResultSetHandler 接口提供了一個(gè)單獨(dú)的方法:Object handle (java.sql.ResultSet .rs)。北京傳智播客教育 ResultSetHandler 接口的實(shí)現(xiàn)類ArrayHandler:把結(jié)果集中的第一行數(shù)據(jù)轉(zhuǎn)成對(duì)象數(shù)組。ArrayListHandler:把結(jié)果集中的每一行數(shù)據(jù)都轉(zhuǎn)成一個(gè)數(shù)組,再存放到List中。BeanHandler:將結(jié)果集中的第一行數(shù)據(jù)封裝到一個(gè)對(duì)應(yīng)的JavaBean實(shí)例中。BeanListHandler:將結(jié)果集中的每一行數(shù)據(jù)都封裝到一個(gè)對(duì)應(yīng)的JavaBean實(shí)例中,存放到List里。北京傳智播客教育 ResultSetHandler 接口的實(shí)現(xiàn)類ColumnListHandler:將結(jié)果集中某一
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025上海市建筑安全員-C證考試(專職安全員)題庫及答案
- 深圳技術(shù)大學(xué)《高分子材料助劑及配方設(shè)計(jì)》2023-2024學(xué)年第二學(xué)期期末試卷
- 河南信息統(tǒng)計(jì)職業(yè)學(xué)院《納稅籌劃與實(shí)務(wù)》2023-2024學(xué)年第二學(xué)期期末試卷
- 2024-2025學(xué)年河南省開封市五縣聯(lián)考高二上學(xué)期第二次月考(期中)歷史試卷
- 山西國際商務(wù)職業(yè)學(xué)院《給排水管道工程》2023-2024學(xué)年第二學(xué)期期末試卷
- 鶴壁能源化工職業(yè)學(xué)院《營養(yǎng)與食品衛(wèi)生學(xué)2》2023-2024學(xué)年第二學(xué)期期末試卷
- 2025青海省建筑安全員-C證(專職安全員)考試題庫
- 2025黑龍江省安全員B證考試題庫及答案
- 福建衛(wèi)生職業(yè)技術(shù)學(xué)院《組織胚胎學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 大連財(cái)經(jīng)學(xué)院《VisualBasic程序設(shè)計(jì)》2023-2024學(xué)年第二學(xué)期期末試卷
- 高速公路改擴(kuò)建工程路基標(biāo)準(zhǔn)化
- 水泥攪拌樁記錄表格范本
- DL∕T 458-2020 板框式旋轉(zhuǎn)濾網(wǎng)
- GB∕T 8163-2018 輸送流體用無縫鋼管
- Windows Azure云平臺(tái)基本操作手冊(cè)
- 短視頻:策劃制作與運(yùn)營課件
- T∕ASC 17-2021 電動(dòng)汽車充換電設(shè)施系統(tǒng)設(shè)計(jì)標(biāo)準(zhǔn)
- 水閘設(shè)計(jì)步驟計(jì)算書(多表)
- PowerPoint使用技巧培訓(xùn)課件(共35張)
- SMA瀝青路面的設(shè)計(jì)與施工
- 腎內(nèi)科相關(guān)基礎(chǔ)知識(shí)學(xué)習(xí)教案
評(píng)論
0/150
提交評(píng)論