97超级碰碰碰久久久_精品成年人在线观看_精品国内女人视频免费观_福利一区二区久久

如何SQL數(shù)據(jù)庫操作在WCF中的應用

  • 相關推薦

如何SQL數(shù)據(jù)庫操作在WCF中的應用

  1 WCF編程模型

  Windows Commuunication Foundation(WCF)[1]是統(tǒng)一的編程模型,用來為微軟平臺編寫分布式應用,它涵蓋了之前出現(xiàn)的多種技術,是面向服務(SOA)思想的一個具體應用。WCF通過SOAP(Simple Object Access Protocal 簡單對象訪問協(xié)議)[2]能夠方便訪問分布在異構網(wǎng)絡中的不同應用。WCF實際上構建了一個框架,這個框架實現(xiàn)了在互聯(lián)系統(tǒng)中各個Application之間通信。

  基于WCF的開發(fā)主要分為服務端和客戶端應用兩部分。服務端包括契約的定義、實現(xiàn)和寄宿三方面;客戶端包括客戶端代理的生成和服務的實現(xiàn)。構建一個典型的解決方案包括4個項目[3]:①Contracts:定義服務契約(Service Contract),引用System.ServiceMode程序集(WCF框架的絕大部分實現(xiàn)和API定義在該程序集中);說明要實現(xiàn)什么服務;②Services:提供WCF服務的實現(xiàn)。實現(xiàn)定義在Contracts中相應的服務契約,說明如何實現(xiàn)Contracts定義的服務;③Hosting:實現(xiàn)對定義在Services項目中服務的寄宿,該項目須同時引用Contracts和Services兩個項目和System.ServiceMode程序集,啟動和關閉服務、實例化Service類并提供服務的訪問地址和通信方式;④Client:生成終結點、綁定、契約相關服務代理類,通過代理類完成最終服務。

  2 WCF中SQL Server常用操作

  WCF中的編程語言是C#,C#對數(shù)據(jù)庫的操作基于ADO.NET對象模型,該對象模型包括數(shù)據(jù)提供程序和DataSet組件,數(shù)據(jù)提供程序有4個,分別是:Connection對象、Command對象、DataAdapter對象和DataReader對象,WCF主要使用這幾個對象對數(shù)據(jù)庫進行操作。

  2.1 數(shù)據(jù)庫連接

  本例中定義了兩個方法,分別實現(xiàn)數(shù)據(jù)庫的連接和關閉。

  2.2 Services數(shù)據(jù)庫查詢、插入、更新和刪除

  在Contracts中定義了一系列和數(shù)據(jù)庫操作相關的接口,在Services中實現(xiàn)了數(shù)據(jù)庫的打開和關閉服務,對數(shù)據(jù)的增刪改查也是在Services中實現(xiàn)的。數(shù)據(jù)的增刪改查操作通過DML(Data Manipulation Language)語句實現(xiàn),DML包括4種基本操作,即INSERT、UPDATE、SELECT和DELETE,分別對應插入、更新、查詢和刪除操作。

  (5)HOSTING托管

  本例通過IIS托管相應服務。

  3 Client數(shù)據(jù)顯示

  3.1 生成客戶端代理

  WCF生成客戶端代理的方法有多種:硬編碼代理類、通過SvcUtil.exe和添加服務引用。本文通過添加服務引用生成了ServiceReference1.ServiceClient代理類,通過代理類的對象可以調(diào)用Services中定義的服務。

  3.2 客戶端查詢數(shù)據(jù)實現(xiàn)

  (1)登陸實現(xiàn)

  以上代碼實現(xiàn)了整表數(shù)據(jù)查詢,并綁定到數(shù)據(jù)控件GridView中顯示。

  4 結語

  本文給出了一個基于WCF的數(shù)據(jù)庫訪問完整應用,在WCF架構下,通過ADO.NET常用數(shù)據(jù)庫組件對SQL Server數(shù)據(jù)庫進行訪問,實現(xiàn)增刪改查相關業(yè)務,并在客戶端完成調(diào)用,實現(xiàn)不同應用。

  WCF架構依次分為:客戶層→服務層(業(yè)務邏輯層、數(shù)據(jù)訪問層)。本文例子不足之處是業(yè)務邏輯層和數(shù)據(jù)訪問層沒有分離,今后的改進中可以更加清晰這兩層關系。