Entity Framework 6 Recipes 2nd Edition(9-5)譯->刪除一個斷開的實體

来源:http://www.cnblogs.com/kid1412/archive/2016/01/19/5142047.html
-Advertisement-
Play Games

9-5. 刪除一個斷開的實體問題我們要把一個把WCF上取回的對象做上刪除的標誌.解決方案假設我們有如Figure 9-5所示實體的支付與票據的模型.Figure 9-5. 一個支付與票據的模型我們的模型展示了支付記錄與票據的關係。在應用程式中,我們用客戶端與用WC封裝EF數據訪問交互. 在我們的例子...


9-5. 刪除一個斷開的實體

問題

我們要把一個把WCF上取回的對象做上刪除的標誌.

解決方案

假設我們有如Figure 9-5所示實體的支付與票據的模型.

 

Figure 9-5. 一個支付與票據的模型

我們的模型展示了支付記錄與票據的關係。在應用程式中,我們用客戶端與用WC封裝EF數據訪問交互

. 在我們的例子中,我們要用WCF服務刪除Payment (支付)實體。為儘可能簡單,我們創建一個WCF服務庫並且定義模型:

1.右擊解決方案,選擇新項目,選擇WCF ➤WCF服務庫,並命名為:Recipe5

2. 右擊Recipe5 項目➤添加➤新建項,選擇“數據” ➤ ADO.NET 實體數據模型. 根據嚮導,添加 Invoice 和 Payment 表. 簡單起見,我們刪除了Invoice實體的導航屬性Payments(在Invoice實體的Payments屬性上右擊,選擇“從模型刪除”)右擊Payment 實體的TimeStamp 屬性, 選擇“屬性”, 設置“併發模式”為Fixed. 這樣會使TimeStamp做為併發控制,當刪除或更新實體時,它的值將作為SQL語句的Where條件的一部分,3. 用Listing 9-27里的代碼,改變IService1.cs文件里的服務定義.

Listing 9-27. The Service Contract for Our WCF Service

    [ServiceContract]

    public interface IService1

    {

        [OperationContract]

        Payment InsertPayment();

 

        [OperationContract]

        void DeletePayment(Payment payment);

}

4. 在Service1.cs文件中, 實現服務,如Listing 9-28所示.

Listing 9-28. The Implementation of Our Service Contract

  public class Service1 : IService1

    {

 

        public Payment InsertPayment()

        {

            using (var context = new EFRecipesEntities())

            {

                //刪除之前的測試數據

                context.Database.ExecuteSqlCommand("delete from chapter9.payment");

                context.Database.ExecuteSqlCommand("delete from chapter9.invoice");

                var payment = new Payment

                {

                    Amount = 99.95m,

                    Invoice = new Invoice { Description = "Auto Repair" }

                };

                context.Payments.Add(payment);

                context.SaveChanges();

                return payment;

            }

        }

 

        public void DeletePayment(Payment payment)

        {

            using (var context=new EFRecipesEntities())

            {

                context.Entry(payment).State = EntityState.Deleted;

                context.SaveChanges();

            }

        }

}

5. 為測試服務, 需要一個客戶端. 在解決方案里添加一個新的控制台應用程式項目

. 客戶端代碼如Listing 9-29所示. 在WCF上右擊,調試➤啟動新實例,再在控制台項目上右擊➤添加➤服務引用,然後添加對WCF的引用.

Listing 9-29. A Simple Console Application to Test Our WCF Service

    class Program

    {

        static void Main(string[] args)

        {

            var client = new ServiceReference1.Service1Client();

            var payment = client.InsertPayment();

            client.DeletePayment(payment);

        }

}

如果你在Main()方法首行代碼前設置斷點,然後調試,“逐語句”執行,可以看到WCF服務的執行

它是如何工作的

在本小節, 我們演示了客戶端調用服務對斷開連接的實體進行操作

.在客戶端,我們用InsertPayment() 方法向資料庫插入一個新的  payment. 該方法返回被插入的

payment. 當然  payment 返回給客戶端後就從DbContext中斷開連接.實際上DbContext可以在不同的進程里,甚至於在不同電腦上,

我們用DeletePayment() 方法來把資料庫中的Payment刪除  . 這個方法中 (見Listing 9-28), 我們調用DbContext 的Entry() 方法,並傳遞一個 Payment參數. 然後把Payment實體的屬性設置為EntityState.Deleted,接著SaveChanges() 方法會生成一條刪除的SQL語句,並把數據從資料庫中刪除. 因為我們用了外鍵關聯, 併發屬性TimeStamp是必需的,EF會在SQL的Where子句中使用到。

用這種方式解決迸發. 會遇到一個問題,當你的POCO類有一個或更多複合型屬性時,因為複合類型,在EF里是被重視的,不能為null,簡單和解決辦法是:為複合類型創建一個虛擬的實例。如果你讓複合類型為null,SaveChanges()方法將會拋出一個異常。

如果在多對1和0..1中使用一個獨立關聯,EF要求它們的實體鍵具有正確的值,以為修改和刪除生成Where子句. 在我們例子里,如果在Invoice和Payment中有一個獨立關聯,我們需要給Invoice的InvoiceId導航設置正確的值,來關聯Invoice實例.這樣Where子句里將會包含PaymentId, TimeStamp, 和InvoiceId.

===================================================================

■■註意:當用EF實例一個N層架構時,應慎重地考慮是否用分配外鍵來關聯相關的實體,獨立關聯比較難實現,並會使你的代碼變得複雜. 對此EF團隊的Arthur Vickers 發佈的whats-the-deal-with-mapping-foreign-keys-using-the-entity-framework 博客,有個很好的解釋.當然也歡迎你細讀他的EF的其它文章.

=======================================================================

如果實體對象包含多個獨立關聯,設置它們就是件乏味的事,你可以簡單地從資料庫重新取回然後再刪除,這樣會使你代碼簡單些,但是當你從資料庫重新取回,EF將重寫這些實體間關係

, 當然你可以有NoTracking 選項關閉context 跟蹤來解決.

如果本小節我們用獨立關聯的方式,為已經載入了Payment 實體做刪除標誌時,EF將會對Payment和相關聯的Invoice做上刪除標誌。

同樣地,結果的SQL名句的Where子句包含PaymentId, TimeStamp, and InvoiceId列。

在獨立關聯在刪除實體的另一個選擇是:預先載入相關聯的實體,然後將整個對象圖傳給WCF或是Web API來進行刪除。就我們的實例,我們可以預先載入Invoice和相關的Payment實體。如果我們要刪除Payment實體,我們需要回傳包含Invoice實體的整個對象給服務。不過這樣會消費更多帶寬有更多序列處處理的時間,所以它可能帶來的好處還比不上消耗。

附:創建示例用到的資料庫的腳本文件


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 關於Ajax說法錯誤的是( )。(選擇一項)MVC是一種流行的軟體設計模式,它把系統分為三個模塊。三個模塊為( )。在ASP.NET中,關於WebService的說法正確的是( ).NET中Object類是所有類的基類,用戶自定義的類部預設地繼承這個類。以下選項不屬於Object類的方法的是( )。...
  • 訂單揀貨完成後,需要把訂單裝箱打包,並列印客戶地址信息。訂單打包的操作流程先是掃描訂單號,然後掃描商品條碼。 1.訂單打包 列印包裝箱面單 2.訂單發貨 訂單打包完成後就等待發貨,快遞公司來拉貨的時候,進行訂單發貨交接,訂單發貨界面如下
  • 本篇不涉及具體代碼,而是把實際開發UWP APP的過程中,遇到的不同設備,不同解析度顯示效果差異的問題進行討論。希望能夠拋磚引玉,和各位擦出一些火花。 蜀黍我目前是在做一套牛逼的UWP APP啦,目標是能跑在各種尺寸不同,解析度不同的PC,Phone和Tablet上。無論是從代碼的複雜度還是實...
  • 今天給大家分享的內容基於前幾天收到的一條留言信息,留言內容是這樣的:看了這位網友的留言相信有不少剛接觸開發的童鞋們也會有同樣的困惑,除了用新建類作為橋梁之外還有什麼好的辦法?很多童鞋肯定會想到DataSet,不錯,DataSet完全可以實現各種數據集的傳遞,而且還很方便,但是一般我們更推薦使用Lis...
  • TopShelf簡介 個人理解:開源、跨平臺的服務框架。提供一種方式以控制台編寫windows服務,與windows服務相比,目前只發現便於調試。 官網網站:http://docs.topshelf-project.com/en/latest/index.htmlTopShelf基本用法...
  • 9-6. 管理斷開時的併發問題想要確保只接受在WCF客戶端併發令牌未被修改的實體。解決方案我們有一個如Figure 9-6所示的模型.Figure 9-6訂單實體模型我們想通過WCF服務來更新一個order ,而要確保這個order 在我們上次取回後沒有發生過其它修改。稍後我們將演示兩個不同的方式....
  • C#用副線程去試圖修改主線程的UI控制項會報出異常,解決方案是使用副線程註冊事件通知主線程自己去修改UI控制項在winform中,方法如下private void button1_Click(object sender, EventArgs e){ Thread myThread = new Th...
  • WCF
    正在準備中
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...