久久综合丝袜日本网手机版,日韩欧美中文字幕在线三区,亚洲精品国产品国语在线,极品在线观看视频婷婷

      <small id="aebxz"><menu id="aebxz"></menu></small>
    1. 如何SQL數(shù)據(jù)庫操作在WCF中的應(yīng)用

      時(shí)間:2022-06-24 20:55:31 數(shù)據(jù)庫操作系統(tǒng) 我要投稿
      • 相關(guān)推薦

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

        1 WCF編程模型

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

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

        2 WCF中SQL Server常用操作

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

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

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

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

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

        (5)HOSTING托管

        本例通過IIS托管相應(yīng)服務(wù)。

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

        3.1 生成客戶端代理

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

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

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

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

        4 結(jié)語

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

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