




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、GBU客戶化開發(fā)中心伙伴培訓(xùn)課程N(yùn)C數(shù)據(jù)庫操作數(shù)據(jù)庫操作何勝利2007-03-25 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)找出發(fā)展機(jī)edesafaaaaadsdfdffdd會(huì)并進(jìn)行初步篩選會(huì)并進(jìn)行初步篩選NCV5以前版本的典型代碼以前版本的典型代碼1.定義sql語句: String strSql=“select . From .where .”2.定義連接: con = getConnection()3.定義stmt: stmt = con.prepareStatement(strSql)4.給條件賦值:stmt.setString(1, key)5.執(zhí)行查
2、詢:ResultSet rs = stmt.executeQuery()6.處理結(jié)果集:while (rs.next() rs.getString(1); rs.getDecimal(2);. 7.處理異常關(guān)閉連接: stmt.close(); con.close(); 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營弊端弊端:嵌入大量SQL語句,冗余是不可避免的 一次又一次地編寫相同的普通代碼 ,工作效率低代碼難以維護(hù),表結(jié)構(gòu)一點(diǎn)小改動(dòng)就難以承受數(shù)據(jù)庫訪問異常不統(tǒng)一 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成
3、果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營V5新的數(shù)據(jù)庫訪問框架新的數(shù)據(jù)庫訪問框架 JDBC FrameWork 1. 靈活 2. 簡潔3. 高的容錯(cuò)性4. 異常的統(tǒng)一處理DataBaseJDBCAPIJDBCFrameworkDataAccessObjectBusinessService業(yè)務(wù)委托接口,提供EJB封裝數(shù)據(jù)訪問對(duì)象,組織數(shù)據(jù)訪問邏輯提供統(tǒng)一的數(shù)據(jù)操作訪問,簡化數(shù)據(jù)訪問操作 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營PersistenceMana
4、ger 管理連接會(huì)話的生命周期,并提供了對(duì)單表管理連接會(huì)話的生命周期,并提供了對(duì)單表VO操作的常用實(shí)現(xiàn)操作的常用實(shí)現(xiàn) JdbcSession 對(duì)對(duì)JDBC的的API封裝和簡化封裝和簡化SQLParameter 封裝執(zhí)行封裝執(zhí)行SQL的參數(shù)的參數(shù)ResultSetProcessor 結(jié)果集處理回調(diào)接口,封裝結(jié)果集處理結(jié)果集處理回調(diào)接口,封裝結(jié)果集處理DbException 封裝不同數(shù)據(jù)庫的異常,和統(tǒng)一處理不同數(shù)據(jù)庫的封裝不同數(shù)據(jù)庫的異常,和統(tǒng)一處理不同數(shù)據(jù)庫的Error CodeBaseDAO / IUAPQueryBS / IVOPersistence 管理連接會(huì)話的生命周期,提供了對(duì)單表管理
5、連接會(huì)話的生命周期,提供了對(duì)單表VO操作的常用實(shí)現(xiàn)操作的常用實(shí)現(xiàn) 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營1.前臺(tái)數(shù)據(jù)訪問前臺(tái)數(shù)據(jù)訪問使用使用IVOPersistence服務(wù)組件,進(jìn)行增刪改操作;服務(wù)組件,進(jìn)行增刪改操作;使用使用IUAPQueryBS服務(wù)組件,進(jìn)行查詢操作。服務(wù)組件,進(jìn)行查詢操作。 IUAPQueryBS iUAPQueryBS = (IUAPQueryBS)NCLocator.getInstance().lookup(IUAPQueryBS.class.getName(); iUAP
6、QueryBS. executeQuery()executeQuery() 2.后臺(tái)數(shù)據(jù)訪問后臺(tái)數(shù)據(jù)訪問 使用使用BaseDAO工具類,進(jìn)行單表對(duì)象的工具類,進(jìn)行單表對(duì)象的CRUD操作;操作;使用使用PersistenceManager,進(jìn)行單表對(duì)象的進(jìn)行單表對(duì)象的CRUD操作操作 new BaseDAO(). insertObject()insertObject() 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營JdbcSession的創(chuàng)建的創(chuàng)建 PersistenceManagersessionManag
7、er=PersistenceManager.getInstance();tryJdbcSessionsession=sessionManager.getJdbcSession();/數(shù)據(jù)庫訪問操作數(shù)據(jù)庫訪問操作session.insert();session.update();session.query();catch(DbExceptione)finallysessionManager.release();/需要關(guān)閉會(huì)話 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營String sql = select
8、* from bd_deptdoc; /構(gòu)造查詢語句構(gòu)造查詢語句List list = (List) session.executeQuery(sql, new ArrayListProcessor();String sql = select * from bd_deptdoc where dept_code=?;SQLParameter param = new SQLParameter(); /構(gòu)造參數(shù)對(duì)象構(gòu)造參數(shù)對(duì)象param.addParam(“aaa”); /添加參數(shù)添加參數(shù)List list=(List) session.executeQuery(sql, param, new Ar
9、rayListProcessor(); 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營String sql = update bd_deptdoc set dept_code =aaawhere dept_code=bbb; session.executeUpdate(sql);String sql = update bd_deptdoc set dept_code =aaawhere dept_code=?”; SQLParameter param = new SQLParameter(); /構(gòu)造參數(shù)對(duì)象
10、構(gòu)造參數(shù)對(duì)象param.addParam(“bbb”); /添加參數(shù)添加參數(shù)session.executeUpdate(sql, param); 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營String sql = update bd_deptdoc set dept_code =aaa where dept_code=bbb; session.addBatch(sql); /添加需要執(zhí)行的同構(gòu)添加需要執(zhí)行的同構(gòu)SQLint rows = session.executeBatch(); /執(zhí)行執(zhí)行Strin
11、g sql = update bd_deptdoc set dept_code =aaa where dept_code=?”; SQLParameter param = new SQLParameter(); /構(gòu)造參數(shù)對(duì)象構(gòu)造參數(shù)對(duì)象param.addParam(“bbb”); /添加參數(shù)添加參數(shù)session.addBatch(sql, param); /添加需要執(zhí)行的同構(gòu)添加需要執(zhí)行的同構(gòu)SQLint rows = session.executeBatch(); /執(zhí)行執(zhí)行 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步
12、篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營特殊參數(shù)特殊參數(shù)1. Null參數(shù)參數(shù)param.addNullParam(java.sql.Types.INTEGER);2. Blob參數(shù)參數(shù)param.addBlobParam (new Object(); 3. Clob參數(shù)參數(shù)param.addClobParam (new String(); 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營結(jié)果集合的處理結(jié)果集合的處理 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩
13、選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營ArrayProcessor數(shù)組處理器,返回一個(gè)對(duì)象數(shù)組,結(jié)果集中只有一行數(shù)據(jù),其中結(jié)果集中每一列對(duì)應(yīng)數(shù)組的一個(gè)元素 ArrayListProcessor數(shù)組集合處理器,返回一個(gè)ArrayList集合,集合中的每一個(gè)元素是一個(gè)數(shù)組,每個(gè)數(shù)組對(duì)應(yīng)結(jié)果集中的一行數(shù)據(jù),其中結(jié)果集中每一列對(duì)應(yīng)數(shù)組的一個(gè)元素 MapProcessorHashMap處理器,返回一個(gè)HashMap,結(jié)果集中只有一行數(shù)據(jù),其中結(jié)果集合中每一列的列名和列值對(duì)應(yīng)HashMap的一個(gè)關(guān)鍵字和相應(yīng)的值 MapListProcessorHashMap集合處理器,返回一個(gè)ArrayList集合,集合中的每一個(gè)元素是一個(gè)
14、HashMap,每個(gè)HashMap對(duì)應(yīng)結(jié)果集中的一行數(shù)據(jù),其中結(jié)果集合中每一列的列名和列值對(duì)應(yīng)HashMap的一個(gè)關(guān)鍵字和相應(yīng)的值 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營BeanProcessor值對(duì)象處理器,返回一個(gè)JavaBean,結(jié)果集中只有一行數(shù)據(jù),該處理器能自動(dòng)把結(jié)果集中的值按列的名稱映射到j(luò)avaBean中,如結(jié)果集中有名稱為”name”的字段,那么只要該java對(duì)象中有g(shù)etName()方法就能把結(jié)果集合中”name”對(duì)應(yīng)的值映射到對(duì)象中 BeanListProcessor值對(duì)象集合處理
15、器,返回一個(gè)ArrayList集合,集合中的每一個(gè)元素是一個(gè)javaBean,每個(gè)javaBean對(duì)應(yīng)結(jié)果集合中一行數(shù)據(jù),其中每個(gè)JavaBean中的數(shù)據(jù)映射關(guān)系和BeanProcess同理 ColumnProcessor列值處理器,返回一個(gè)Java對(duì)象,結(jié)果集中只有一行數(shù)據(jù),該對(duì)象對(duì)應(yīng)與結(jié)果集中某一列的值,該處理器通過結(jié)果集列的序號(hào)或名稱來確定列 內(nèi)部經(jīng)營內(nèi)部經(jīng)營人員經(jīng)營人員經(jīng)營成果經(jīng)營成果經(jīng)營客戶經(jīng)營客戶經(jīng)營找出發(fā)展機(jī)會(huì)并進(jìn)找出發(fā)展機(jī)會(huì)并進(jìn)行初步篩選行初步篩選項(xiàng)目經(jīng)營項(xiàng)目經(jīng)營自定義的結(jié)果集處理器自定義的結(jié)果集處理器publicclassCustomProcessorextendsBaseProcessorpublicObjectproces
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 項(xiàng)目的可行性分析與評(píng)估計(jì)劃
- 2025年電子廚房秤項(xiàng)目建議書
- 2025年微球載體材料合作協(xié)議書
- 醫(yī)院銷售合同
- 電商交易平臺(tái)的商品展示與服務(wù)免責(zé)協(xié)議書
- Oxadixyl-Standard-生命科學(xué)試劑-MCE
- Dimethenamide-P-Standard-生命科學(xué)試劑-MCE
- 4-Aminonicotinic-acid-生命科學(xué)試劑-MCE
- 2-3-Isopropylideneguanosine-生命科學(xué)試劑-MCE
- 幼兒繪本小藍(lán)和小黃讀后感
- 五年級(jí)下冊(cè)音樂課程綱要
- 《酒后駕車的危害》課件
- 食材配送、包裝、運(yùn)輸、驗(yàn)收、售后服務(wù)方案應(yīng)急預(yù)案
- 萬千教育學(xué)前讀懂兒童的思維:支持自主游戲中的圖式探索
- 無障礙設(shè)施監(jiān)理實(shí)施細(xì)則
- 中石化YC分公司易捷便利店市場營銷策略研究
- 可轉(zhuǎn)換病區(qū)應(yīng)急預(yù)案與流程
- 《燃放煙花的利與弊》課件
- 醫(yī)院護(hù)理培訓(xùn)課件:《病區(qū)環(huán)境管理查房》
- 《小羊和蝴蝶》繪本故事
- 鋼筋工理論考試題庫及答案
評(píng)論
0/150
提交評(píng)論