個(gè)人開發(fā)框架總結(jié)(一).doc_第1頁
個(gè)人開發(fā)框架總結(jié)(一).doc_第2頁
個(gè)人開發(fā)框架總結(jié)(一).doc_第3頁
個(gè)人開發(fā)框架總結(jié)(一).doc_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

個(gè)人開發(fā)框架總結(jié)(一) 個(gè)人開發(fā)框架總結(jié) (一)個(gè)人開發(fā)框架總結(jié) (一)。 在開發(fā)過程中,大家可能都發(fā)現(xiàn),形成一套個(gè)人開發(fā)風(fēng)格是相當(dāng)重要,這也可以延伸為整個(gè)團(tuán)隊(duì)的開發(fā)模式,甚至形成一個(gè)有形的開發(fā)框架。 我經(jīng)過這一兩年的摸索,不斷的完善,現(xiàn)在大體形成了幾個(gè)東東,自己感覺還不錯(cuò),所以想貼出來與大家一起分享,如有需要的朋友,可以直接與我聯(lián)系。 大體有以下幾個(gè)類庫FaibClass.Data數(shù)據(jù)訪問庫FaibClass.Common.Windows WinForm框架庫FaibClass.Windows.Forms WinForm控件庫(目前只有TreeList及一些TextBox控件)FaibClass.Update在線更新庫在以后的幾天里將分別做一些介紹 一、FaibClass.Data主要是提供數(shù)據(jù)訪問操作的類庫,可支持SqlServer、Oracle、及各種OleDb數(shù)據(jù)庫。 DataHelper核心類提供各種數(shù)據(jù)訪問方法。 先說一下它的幾個(gè)方法和屬性ExecuteDataTable填充數(shù)據(jù)到DataTable,共12種重載ExecuteNonQuery執(zhí)行Sql語句ExecuteReader執(zhí)行查詢語句返回IDataReader ExecuteScalar執(zhí)行查詢,返回當(dāng)個(gè)結(jié)果FillDataset填充DataSet,共12種重載FillModelList填充DataList,共12種重載Update更新DataTable或DataSet,共6種重載BeginTransaction開始事務(wù),支付分布式事務(wù)CommitTransaction提交事務(wù)RollbackTransaction回滾事務(wù)CreateParameters創(chuàng)建參數(shù)集,因?yàn)槭褂么鎯?chǔ)過程時(shí)SqlServer和Oracle的參數(shù)名稱不一樣,故用這個(gè)方法生成OpenUpdateBag打開更新開關(guān),在使用Update前,要使用這個(gè)方法把相應(yīng)的sql語句保存到內(nèi)存中,以在Update時(shí)能夠更新到數(shù)據(jù)庫CloseUpdateBag關(guān)閉更新開關(guān)ParameterPrefix當(dāng)前數(shù)據(jù)操作的存儲(chǔ)過程參數(shù)名稱的前綴,如SqlServer的和Oracle的:下面是具體的操作類型,SqlServer、Oracle、OleDb都是繼承自DataHelper的,但并未為每一個(gè)操作類都寫出各種數(shù)據(jù)操作的方法,這也主要是為了好維護(hù),這幾個(gè)類同時(shí)實(shí)現(xiàn)IDataProvider接口,這個(gè)接口就是為每種類型提供DbConnection、DbParameter、DataAdapter、DbCommand等。 如SqlServer里是這樣寫到的public classSqlServer:DataHelper,IDataProvider#region IDataConverterIDbConnection IDataProvider.GetDbConnection()SqlConnection conn=new SqlConnection(ConnectionString);conn.StateChange+=new StateChangeEventHandler(base.OnStateChange);return conn;IDbDataAdapter IDataProvider.GetDataAdapter()return newSqlDataAdapter();IDataParameter IDataProvider.GetParameter()return newSqlParameter();IDataParameterIDataProvider.GetParameters(int Count)return newSqlParameterCount;IDbCommand IDataProvider.GetCommand(IDbCommand mand)return mandas SqlCommand;void IDataProvider.GetCommandBuilder(IDbDataAdapter DataAdapter,DataTable DataTable,DataViewRowState dataViewRowState)SqlDataAdapter adapter=(SqlDataAdapter)DataAdapter;SqlCommandBuilder cmdb=new SqlCommandBuilder(adapter);#endregion這樣,每一個(gè)類就好維護(hù)了,Oracle就使用OracleConnection,OleDb就使用OleDbConnection。 Parameter存儲(chǔ)過程參數(shù)類,這跟System.Data里的差不多,都是實(shí)現(xiàn)同樣的一個(gè)功能,只是說使用這個(gè)的時(shí)候,ParameterName不用具體的加入或:這樣的前綴。 ParameterCollection存儲(chǔ)過程參數(shù)集合類,這里面特別的有幾個(gè)方法FromDataModel從模型轉(zhuǎn)換為存儲(chǔ)參數(shù)。 可以根據(jù)具體的模型,將所有屬性轉(zhuǎn)換為存儲(chǔ)過程參數(shù),以為添加或修改作準(zhǔn)備。 Format可以格式化Sql查詢語句,比如在使用添加或修改的時(shí)候,可以這樣使用dataHelper.ExecuteNonQuery(params.Format(insert intotable(0)values(1),params);dataHelper.ExecuteNonQuery(params.Format(update tableset0),param

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論