轉(zhuǎn)帖|其它|編輯:郝浩|2010-08-17 12:58:51.000|閱讀 617 次
概述:隨著傳統(tǒng)的數(shù)據(jù)庫(kù)、計(jì)算機(jī)網(wǎng)絡(luò)和數(shù)字通信技術(shù)的飛速發(fā)展,以數(shù)據(jù)分布存儲(chǔ)和分布處理為主要特征的分布式數(shù)據(jù)庫(kù)系統(tǒng)的研究和開(kāi)發(fā)越來(lái)越受到人們的關(guān)注。但由于其開(kāi)發(fā)較為復(fù)雜,在一定程度上制約了它的發(fā)展。基于此,本文提出了在.Net環(huán)境下使用一種新的開(kāi)發(fā)語(yǔ)言C#結(jié)合ADO.Net數(shù)據(jù)訪問(wèn)模型來(lái)開(kāi)發(fā)分布式數(shù)據(jù)庫(kù)系統(tǒng),大大簡(jiǎn)化了開(kāi)發(fā)過(guò)程。
# 界面/圖表報(bào)表/文檔/IDE等千款熱門(mén)軟控件火熱銷(xiāo)售中 >>
隨著傳統(tǒng)的數(shù)據(jù)庫(kù)、計(jì)算機(jī)網(wǎng)絡(luò)和數(shù)字通信技術(shù)的飛速發(fā)展,以數(shù)據(jù)分布存儲(chǔ)和分布處理為主要特征的分布式數(shù)據(jù)庫(kù)系統(tǒng)的研究和開(kāi)發(fā)越來(lái)越受到人們的關(guān)注。但由于其開(kāi)發(fā)較為復(fù)雜,在一定程度上制約了它的發(fā)展。基于此,本文提出了在.Net環(huán)境下使用一種新的開(kāi)發(fā)語(yǔ)言C#結(jié)合ADO.Net數(shù)據(jù)訪問(wèn)模型來(lái)開(kāi)發(fā)分布式數(shù)據(jù)庫(kù)系統(tǒng),大大簡(jiǎn)化了開(kāi)發(fā)過(guò)程。
1 分布式數(shù)據(jù)庫(kù)系統(tǒng)
就其本質(zhì)而言,分布式數(shù)據(jù)庫(kù)系統(tǒng)的數(shù)據(jù)在邏輯上是統(tǒng)一的,而在物理上卻是分散的。與集中式數(shù)據(jù)庫(kù)相比它有如下主要優(yōu)點(diǎn):
· 解決組織機(jī)構(gòu)分散而數(shù)據(jù)需要相互聯(lián)系的問(wèn)題。
· 均衡負(fù)載。負(fù)載在各處理機(jī)間分擔(dān),可避免臨界瓶頸。
· 可靠性高。數(shù)據(jù)分布在不同場(chǎng)地,且存有多個(gè)副本,即使個(gè)別場(chǎng)地發(fā)生故障,不致引起整個(gè)系統(tǒng)的癱瘓。
· 可擴(kuò)充性好。當(dāng)需要增加新的相對(duì)自主的組織單位時(shí),可在對(duì)當(dāng)前機(jī)構(gòu)影響最小的情況下進(jìn)行擴(kuò)充。
分布式數(shù)據(jù)庫(kù)系統(tǒng)雖然有諸多優(yōu)點(diǎn),但它同時(shí)也帶來(lái)了許多新問(wèn)題。如:數(shù)據(jù)一致性問(wèn)題、數(shù)據(jù)遠(yuǎn)程傳遞的實(shí)現(xiàn)、通信開(kāi)銷(xiāo)的降低等,這使得分布式數(shù)據(jù)庫(kù)系統(tǒng)的開(kāi)發(fā)變得較為復(fù)雜。幸運(yùn)的是,微軟的.Net開(kāi)發(fā)環(huán)境為我們提供了C#開(kāi)發(fā)語(yǔ)言和ADO.Net數(shù)據(jù)訪問(wèn)模型,結(jié)合兩者來(lái)開(kāi)發(fā)分布式數(shù)據(jù)庫(kù)系統(tǒng)能夠大大簡(jiǎn)化開(kāi)發(fā)工作。
2 遠(yuǎn)程處理框架和ADO.Net
開(kāi)發(fā)分布式數(shù)據(jù)庫(kù)系統(tǒng)需要解決的兩個(gè)重要問(wèn)題是:各場(chǎng)地間的數(shù)據(jù)通信以及對(duì)數(shù)據(jù)庫(kù)的操作及管理。使用C#結(jié)合ADO.Net能夠高效、可靠地解決這兩方面的問(wèn)題。具體表現(xiàn)為,在C#中通過(guò)使用.Net遠(yuǎn)程處理框架能夠方便地解決數(shù)據(jù)、命令遠(yuǎn)程傳遞問(wèn)題;C#通過(guò)ADO.Net對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作,使分布式數(shù)據(jù)庫(kù)系統(tǒng)中對(duì)數(shù)據(jù)庫(kù)的各種操作變得高效、可靠,同時(shí)易于解決數(shù)據(jù)一致性問(wèn)題。
2.1 .Net遠(yuǎn)程處理框架
實(shí)現(xiàn)數(shù)據(jù)和命令的遠(yuǎn)程傳遞有三種方式。第一種是使用報(bào)文或消息的方式,把要傳送的數(shù)據(jù)轉(zhuǎn)化為流格式,再通過(guò)套接字編程用報(bào)文的形式發(fā)送到遠(yuǎn)程主機(jī)。此種方法麻煩,不易實(shí)現(xiàn)。第二種是使用Web Service,即各遠(yuǎn)程主機(jī)提供一個(gè)數(shù)據(jù)庫(kù)查詢(xún)服務(wù)的Web Service。這種方式只能對(duì)單個(gè)場(chǎng)地進(jìn)行查詢(xún),無(wú)法實(shí)現(xiàn)多場(chǎng)地的聯(lián)合查詢(xún)。第三種是使用.Net遠(yuǎn)程處理框架(.Net Remoting Framework)技術(shù),它將遠(yuǎn)程調(diào)用的技術(shù)細(xì)節(jié)隱藏起來(lái),服務(wù)程序只需通過(guò)簡(jiǎn)單的設(shè)置就可以把本地對(duì)象變成為遠(yuǎn)程提供服務(wù)的遠(yuǎn)程對(duì)象,客戶(hù)端可以像訪問(wèn)本地對(duì)象一樣透明地訪問(wèn)遠(yuǎn)程對(duì)象,所有的消息、報(bào)文等都交給.Net Remoting對(duì)象處理,大大簡(jiǎn)化了開(kāi)發(fā)。遠(yuǎn)程處理的一般過(guò)程如圖1所示:
首先,服務(wù)器端創(chuàng)建一個(gè)服務(wù)器類(lèi)的實(shí)例,遠(yuǎn)程處理系統(tǒng)創(chuàng)建一個(gè)表示該類(lèi)的代理對(duì)象,并向客戶(hù)端對(duì)象返回一個(gè)對(duì)該代理的引用。當(dāng)客戶(hù)端調(diào)用方法時(shí),遠(yuǎn)程處理基礎(chǔ)結(jié)構(gòu)連接檢查類(lèi)型信息,并通過(guò)信道將該調(diào)用發(fā)送到服務(wù)器進(jìn)程。偵聽(tīng)信道獲得該請(qǐng)求并將其轉(zhuǎn)發(fā)給服務(wù)器遠(yuǎn)程處理系統(tǒng),服務(wù)器遠(yuǎn)程處理系統(tǒng)查找(或在必要時(shí)創(chuàng)建)并調(diào)用被請(qǐng)求的對(duì)象。然后,此過(guò)程將反向進(jìn)行,服務(wù)器遠(yuǎn)程處理系統(tǒng)將響應(yīng)捆綁成消息并由服務(wù)器信道發(fā)送到客戶(hù)端信道。最后,客戶(hù)端遠(yuǎn)程處理系統(tǒng)通過(guò)代理將調(diào)用的結(jié)果返回給客戶(hù)端對(duì)象。
2.2 ADO.Net
ADO.Net以XML為核心,是.Net數(shù)據(jù)庫(kù)應(yīng)用程序的解決方案。它使用離線數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)源中的數(shù)據(jù)被緩存到數(shù)據(jù)集(DataSet)對(duì)象中,用戶(hù)無(wú)須鎖定數(shù)據(jù)源,數(shù)據(jù)以XML格式保存。
2.2.1 ADO.Net管理數(shù)據(jù)一致性
在分布式數(shù)據(jù)庫(kù)系統(tǒng)中,很可能出現(xiàn)多個(gè)用戶(hù)同時(shí)訪問(wèn)和修改數(shù)據(jù)的情況,因此,對(duì)于分布式數(shù)據(jù)庫(kù)系統(tǒng),數(shù)據(jù)一致性是不可或缺的。ADO.Net通過(guò)使用樂(lè)觀一致性方案來(lái)控制數(shù)據(jù)一致性(實(shí)際上DataSet對(duì)象被設(shè)計(jì)成支持使用樂(lè)觀一致性控制機(jī)制),即數(shù)據(jù)行只有在數(shù)據(jù)庫(kù)中真正被更新時(shí)才會(huì)被鎖定,而在悲觀一致性方案中,數(shù)據(jù)行在從被提取出來(lái)到在數(shù)據(jù)庫(kù)中更新這段時(shí)間內(nèi)一直被鎖定。因此,使用ADO.Net能夠在更少的時(shí)間內(nèi)響應(yīng)數(shù)量巨大的用戶(hù)。
另外,在分布式數(shù)據(jù)庫(kù)系統(tǒng)中,還會(huì)經(jīng)常遇到當(dāng)用戶(hù)修改自從提取出來(lái)以來(lái)已經(jīng)被修改的行時(shí),違反一致性原則。對(duì)此問(wèn)題ADO.Net也作了很好地解決,即使用DataSet對(duì)象為每一條修改過(guò)的記錄維護(hù)兩個(gè)版本:原始版本和更新版本,在更新的記錄被寫(xiě)回?cái)?shù)據(jù)庫(kù)之前,先要把數(shù)據(jù)集中記錄的原始版本與數(shù)據(jù)庫(kù)中的當(dāng)前版本進(jìn)行比較,如果兩個(gè)版本匹配,就在數(shù)據(jù)庫(kù)中更新記錄;否則,就會(huì)出現(xiàn)違反一致性原則的錯(cuò)誤。
3 實(shí)例開(kāi)發(fā)
一個(gè)家用電器連鎖店設(shè)有一個(gè)總部和許多分店,總部和分店以及各分店之間經(jīng)常需要進(jìn)行各種信息的查詢(xún)(如:商品當(dāng)日價(jià)目表、各店銷(xiāo)售狀況和庫(kù)存信息等),對(duì)此組織機(jī)構(gòu)建立分布式數(shù)據(jù)庫(kù)查詢(xún)系統(tǒng),可實(shí)現(xiàn)總部和各店信息的共享,便于統(tǒng)一管理。
3.1 系統(tǒng)設(shè)計(jì)
3.1.1系統(tǒng)結(jié)構(gòu)圖
系統(tǒng)結(jié)構(gòu)如圖2所示:
總部和各分店都配置了一臺(tái)具有固定IP的服務(wù)器,其它電腦通過(guò)集線器與服務(wù)器相連,總部和各分店的服務(wù)器通過(guò)通信網(wǎng)絡(luò)聯(lián)接起來(lái)。
3.1.2 系統(tǒng)實(shí)現(xiàn)步驟
系統(tǒng)實(shí)現(xiàn)分為三個(gè)主要步驟。首先,為總部和各分店設(shè)計(jì)數(shù)據(jù)庫(kù)。由于數(shù)據(jù)量較大,故采用SQL Server為每個(gè)分店創(chuàng)建銷(xiāo)售和庫(kù)存數(shù)據(jù)庫(kù),同時(shí)為總部創(chuàng)建員工數(shù)據(jù)庫(kù)、整個(gè)連鎖店的存貨數(shù)據(jù)庫(kù)、信用卡客戶(hù)數(shù)據(jù)庫(kù)以及供應(yīng)商信息數(shù)據(jù)庫(kù)等。其次,需要建立一個(gè)提供數(shù)據(jù)庫(kù)服務(wù)(DbServer)的動(dòng)態(tài)鏈接庫(kù)(dll),將查詢(xún)時(shí)所要用到的一些服務(wù)(如:遠(yuǎn)程對(duì)象的發(fā)布和獲取等)和函數(shù)(如:本地異地?cái)?shù)據(jù)表的查詢(xún)、數(shù)據(jù)表的遠(yuǎn)程創(chuàng)建和刪除、表間的連接和合并等)置入該dll中,各分店都需要使用這個(gè)dll,以便查詢(xún)時(shí)對(duì)一些服務(wù)和函數(shù)進(jìn)行調(diào)用。最后,根據(jù)實(shí)際需要開(kāi)發(fā)客戶(hù)端查詢(xún)界面。
3.2系統(tǒng)實(shí)現(xiàn)的關(guān)鍵技術(shù)
3.2.1 遠(yuǎn)程對(duì)象的發(fā)布與獲取
系統(tǒng)運(yùn)行后所要做的第一個(gè)工作是發(fā)布本地的遠(yuǎn)程對(duì)象并獲取其它各店所發(fā)布的遠(yuǎn)程對(duì)象。發(fā)布遠(yuǎn)程對(duì)象時(shí),首先要設(shè)置一個(gè)網(wǎng)絡(luò)端口號(hào),然后創(chuàng)建并注冊(cè)一個(gè)通道,最后發(fā)布該服務(wù)器端的激活對(duì)象。其它場(chǎng)地的服務(wù)器根據(jù)IP地址和網(wǎng)絡(luò)端口號(hào)即可方便地獲取所發(fā)布的遠(yuǎn)程對(duì)象。實(shí)現(xiàn)遠(yuǎn)程對(duì)象發(fā)布和獲取的關(guān)鍵代碼如下:
遠(yuǎn)程對(duì)象的發(fā)布:
//創(chuàng)建一個(gè)通道實(shí)例,port為指定的網(wǎng)絡(luò)端口號(hào)
TcpChannel MyChannel= new TcpChannel (Int32.Parse(port));
//注冊(cè)通道
ChannelServices.RegisterChannel(MyChannel);
//發(fā)布該服務(wù)器端激活對(duì)象
RemotingConfiguration.RegisterWellKnownServiceType( typeof ( DbServer ), "STORE", WellKnownObjectMode.Singleton);
遠(yuǎn)程對(duì)象的獲取:
//根據(jù)IP地址和端口號(hào)獲取相應(yīng)的遠(yuǎn)程對(duì)象
try
{myDbServer=(DbServer)Activator.GetObject(typeof(DbServer),"tcp://"+ip+":"+p+"/STORE"); }
//捕捉異常
catch( NullReferenceException nullExp )
{MessageBox.Show( "指定的url地址不可到達(dá) " + nullExp.Message );}
catch( RemotingException remExp )
{MessageBox.Show( "指定獲得的對(duì)象定義不對(duì)" + remExp.Message );}
3.2.2數(shù)據(jù)庫(kù)的訪問(wèn)
通過(guò)ADO.Net訪問(wèn)數(shù)據(jù)庫(kù),可以方便地連接數(shù)據(jù)庫(kù),將數(shù)據(jù)源中的數(shù)據(jù)導(dǎo)入DataSet對(duì)象中,在DataSet對(duì)象中可對(duì)數(shù)據(jù)表進(jìn)行各種操作,而且DataSet對(duì)象本身也可遠(yuǎn)程傳遞。這為開(kāi)發(fā)分布式數(shù)據(jù)庫(kù)系統(tǒng)帶來(lái)極大方便。實(shí)現(xiàn)數(shù)據(jù)庫(kù)訪問(wèn)的關(guān)鍵代碼如下所示:
//建立數(shù)據(jù)庫(kù)的連接
string SqlConn = "Initial Catalog=Store;Data Source=Localhost;Userid=sa;Password=;";
SqlConnection Conn= new SqlConnection
(SqlConn);
Conn.Open();//打開(kāi)數(shù)據(jù)庫(kù)
//將數(shù)據(jù)源中的數(shù)據(jù)導(dǎo)入到數(shù)據(jù)集對(duì)象
try{
DataSet ds = new DataSet();
DataTable dt=new DataTable("Result");
SqlDataAdapter adapter=new SqlDataAdapter();
SqlCommand mySqlDataSetCmd =new SqlCommand
(CmdString,Conn);//CmdString為要執(zhí)行的命令
adapter.SelectCommand= mySqlDataSetCmd;
adapter.Fill(dt);
ds.Tables.Add(dt); }
finally
{ Conn.Close();//關(guān)閉數(shù)據(jù)庫(kù)的連接}
3.2.3 查詢(xún)
分布式數(shù)據(jù)庫(kù)系統(tǒng)中的查詢(xún)一般分為三類(lèi):本地查詢(xún)、遠(yuǎn)程查詢(xún)和聯(lián)合查詢(xún)。本地查詢(xún)和集中式數(shù)據(jù)庫(kù)的查詢(xún)沒(méi)什么區(qū)別;對(duì)于遠(yuǎn)程查詢(xún),只要獲取遠(yuǎn)程對(duì)象后,調(diào)用查詢(xún)函數(shù),即可方便地實(shí)現(xiàn);最復(fù)雜的是聯(lián)合查詢(xún),涉及到多場(chǎng)地之間數(shù)據(jù)的查詢(xún)、表的遠(yuǎn)程創(chuàng)建、傳遞、連接、合并等技術(shù)。下面以實(shí)例介紹聯(lián)合查詢(xún)的實(shí)現(xiàn)。
第二連鎖店要查詢(xún)離其較近的第三、第四連鎖店中所有北京的供應(yīng)商所供應(yīng)的空調(diào)的庫(kù)存信息以便調(diào)貨,可通過(guò)以下步驟實(shí)現(xiàn)。首先,獲取總部以及第三、第四連鎖店所發(fā)布的遠(yuǎn)程對(duì)象。接著,通過(guò)遠(yuǎn)程對(duì)象在總部創(chuàng)建一臨時(shí)數(shù)據(jù)表t1,將查詢(xún)到的所有北京的供應(yīng)商信息存放在t1表中(各分店只有供應(yīng)商名,并不知其所在地,只有總部才有供應(yīng)商的詳細(xì)信息),再將t1表保存到第三和第四連鎖店。然后讓t1表分別與兩店的庫(kù)存表作連接,找出所有北京供應(yīng)商所供應(yīng)的空調(diào)庫(kù)存信息(如空調(diào)名稱(chēng)、型號(hào)、個(gè)數(shù)、價(jià)格等信息),并將連接結(jié)果t2和t3數(shù)據(jù)表返回到第二連鎖店。最后對(duì)t2和t3兩表進(jìn)行合并,并使用DataGrid控件顯示出來(lái)。上述實(shí)現(xiàn)中,包含了不同場(chǎng)地之間數(shù)據(jù)表的復(fù)制、傳遞、連接等,所用到的一些函數(shù)(如:遠(yuǎn)程創(chuàng)建數(shù)據(jù)表、表與表間的遠(yuǎn)程連接、合并等)都放在dll中,可以方便地調(diào)用。
4 結(jié)束語(yǔ)
利用C#的.Net Remoting技術(shù)能夠方便地解決各場(chǎng)地間數(shù)據(jù)的通信問(wèn)題。另外,C#通過(guò)ADO.Net訪問(wèn)數(shù)據(jù)庫(kù),使得對(duì)數(shù)據(jù)庫(kù)的操作及管理變得更加高效、可靠。這兩種技術(shù)的使用,有效地解決了開(kāi)發(fā)分布式數(shù)據(jù)庫(kù)系統(tǒng)的主要問(wèn)題,大大減輕了系統(tǒng)開(kāi)發(fā)工作量,并且提高了系統(tǒng)的可靠性和安全性。
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請(qǐng)務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請(qǐng)郵件反饋至chenjj@fc6vip.cn
文章轉(zhuǎn)載自:網(wǎng)絡(luò)轉(zhuǎn)載