如何SQL數據庫操作在WCF中的應用
1 WCF編程模型
Windows Commuunication Foundation(WCF)[1]是統一的編程模型,用來為微軟平台編寫分佈式應用,它涵蓋了之前出現的多種技術,是面向服務(SOA)思想的一個具體應用。WCF通過SOAP(Simple Object Access Protocal 簡單對象訪問協議)[2]能夠方便訪問分佈在異構網絡中的不同應用。WCF實際上構建了一個框架,這個框架實現了在互聯繫統中各個Application之間通信。
基於WCF的開發主要分為服務端和客户端應用兩部分。服務端包括契約的定義、實現和寄宿三方面;客户端包括客户端代理的生成和服務的實現。構建一個典型的解決方案包括4個項目[3]:①Contracts:定義服務契約(Service Contract),引用iceMode程序集(WCF框架的絕大部分實現和API定義在該程序集中);説明要實現什麼服務;②Services:提供WCF服務的實現。實現定義在Contracts中相應的服務契約,説明如何實現Contracts定義的服務;③Hosting:實現對定義在Services項目中服務的寄宿,該項目須同時引用Contracts和Services兩個項目和iceMode程序集,啟動和關閉服務、實例化Service類並提供服務的訪問地址和通信方式;④Client:生成終結點、綁定、契約相關服務代理類,通過代理類完成最終服務。
2 WCF中SQL Server常用操作
WCF中的編程語言是C#,C#對數據庫的操作基於對象模型,該對象模型包括數據提供程序和DataSet組件,數據提供程序有4個,分別是:Connection對象、Command對象、DataAdapter對象和DataReader對象,WCF主要使用這幾個對象對數據庫進行操作。
2.1 數據庫連接
本例中定義了兩個方法,分別實現數據庫的'連接和關閉。
2.2 Services數據庫查詢、插入、更新和刪除
在Contracts中定義了一系列和數據庫操作相關的接口,在Services中實現了數據庫的打開和關閉服務,對數據的增刪改查也是在Services中實現的。數據的增刪改查操作通過DML(Data Manipulation Language)語句實現,DML包括4種基本操作,即INSERT、UPDATE、SELECT和DELETE,分別對應插入、更新、查詢和刪除操作。
(5)HOSTING託管
本例通過IIS託管相應服務。
3 Client數據顯示
3.1 生成客户端代理
WCF生成客户端代理的方法有多種:硬編碼代理類、通過和添加服務引用。本文通過添加服務引用生成了iceClient代理類,通過代理類的對象可以調用Services中定義的服務。
3.2 客户端查詢數據實現
(1)登陸實現
以上代碼實現了整表數據查詢,並綁定到數據控件GridView中顯示。
4 結語
本文給出了一個基於WCF的數據庫訪問完整應用,在WCF架構下,通過常用數據庫組件對SQL Server數據庫進行訪問,實現增刪改查相關業務,並在客户端完成調用,實現不同應用。
WCF架構依次分為:客户層→服務層(業務邏輯層、數據訪問層)。本文例子不足之處是業務邏輯層和數據訪問層沒有分離,今後的改進中可以更加清晰這兩層關係。
-
數據庫營銷方案
營銷主要是深挖產品本身的內涵,切合準消費者以及眾多商家的需求,從而讓消費者深刻了解該產品進而購買的過程。下面,小編為大家分享數據庫營銷方案,希望對大家有所幫助!一、項目背景伴隨着全面建設小康社會的推進,城鄉一體化趨勢不斷增強,外出務工人員在社會經濟中扮...
-
自考互聯網數據庫易考點
一、數據字典及其構成數據字典是系統中各類數據描述的集合,是進行詳細的數據收集和數據分析所獲得的主要成果。數據字典通常包括數據項,數據結構,數據流,數據存儲和處理過程五個部分。其中數據項是數據的最小組成單位,若干個數據項可以組成一個數據結構,數據字典通過...
-
刪除數據庫中重複數據的技巧
數據庫的使用過程中由於程序方面的問題有時候會碰到重複數據,重複數據導致了數據庫部分設置不能正確設置……方法一declare@maxinteger,@idintegerdeclarecur_rowscursorlocalforselect主字段,count(*)from表名groupby主字段havingcount(*)>1opencur_rowsfetchc...
-
系統項目總結報告模版
【項目總結報告1】一項目介紹1.1項目名稱CNC高速全自動繞線機1.2項目由來性能穩定、質量可靠、效率高的設備是產品質量和產量的保證。目前對於繼電器、變壓器、電感、高壓點火線圈等產品的繞線,行業內廠都採用手工單軸繞線,手工纏腳,手工拉斷,手工上下料等。這種方...