Entity Framework 6 Recipes 2nd Edition(10-10)譯 - > 為TPH繼承的插入、更新、刪除操作映射到存儲過程

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

10-10. 為TPH繼承的插入、更新、刪除操作映射到存儲過程問題TPH繼承模型,想把它的插入、修改、刪除操作映射到存儲過程Solution假設資料庫有一個描述不同種類的產品表(Product )(見Figure 10-13). 而且為這個表的每種產品創建了創建了派生模型,這個模型如Figure 1...


10-10. 為TPH繼承的插入、更新、刪除操作映射到存儲過程

問題

TPH繼承模型,想把它的插入、修改、刪除操作映射到存儲過程

Solution

假設資料庫有一個描述不同種類的產品表(Product )(見Figure 10-13). 而且為這個表的每種產品創建了創建了派生模型,這個模型如Figure 10-14.

 

Figure 10-13. 一個含有鑒別列(ProductType的產品表, 表的每行按該列的值劃分不同的產品

 

Figure 10-14. TPH繼承形式的模型

接下來把這個模型的插入、更新、刪除操作映射到存儲過程:

1. 在資料庫里,創建  Listing 10-26 所示的存儲過程. 這些存儲過程為Book 和 DVD 實體處理插入、更新、刪除操作。

Listing 10-26. The Stored Procedure We Map to the Insert, Update, and Delete Actions for the Model

create procedure [chapter10].[InsertBook](@Title varchar(50), @Publisher varchar(50))

as

begin

insert into Chapter10.Product (Title, Publisher, ProductType) values(@Title,@Publisher, 'Book')

select SCOPE_IDENTITY() as ProductId

end

go

 

create procedure [chapter10].[UpdateBook](@Title varchar(50), @Publisher varchar(50), @ProductId int)

as

begin

update Chapter10.Product set Title = @Title, Publisher = @Publisher where ProductId = @ProductId

end

go

 

create procedure [chapter10].[DeleteBook](@ProductId int)

as

begin

delete from Chapter10.Product where ProductId = @ProductId

end

go

 

create procedure [chapter10].[InsertDVD](@Title varchar(50), @Rating varchar(50))

as

begin

insert into Chapter10.Product (Title, Rating, ProductType) values(@Title, @Rating, 'DVD')

select SCOPE_IDENTITY() as ProductId

end

go

 

create procedure [chapter10].[DeleteDVD](@ProductId int)

as

begin

delete from Chapter10.Product where ProductId = @ProductId

end

go

 

create procedure [chapter10].[UpdateDVD](@Title varchar(50), @Rating varchar(50), @ProductId int)

as

begin

update Chapter10.Product set Title = @Title, Rating = @Rating where ProductId = @ProductId

end

2.右擊模型的設計視圖,選擇“從資料庫更新模型. 選擇新建的存儲過程, 單擊“完成”,完成更新.

3.右擊 Book 實體,選擇“存儲過程映射”.映射 InsertBook,UpdateBook, 和DeleteBook 存儲過程到相應的操作。為插入操作綁定ProductId列 (見 Figure 10-15).

 

Figure 10-15. 映射存在過程到Book實體的插入、更新、刪除操作. 特別註意要把插入操作綁定結果列綁定到ProductId.

4. 右擊 DVD 實體,選擇“存儲過程映射”, 映射 InsertBook,UpdateBook, 和DeleteBook 存儲過程到相應的操作。為插入操作綁定ProductId列(見 Figure 10-16).

 

它是如何工作的?

我們為Book和DVD實體的插入、更新、刪除操作創建了存儲過程,並且引入到模型. 引入後,我們把它們分別映射到相應的實體的相應操作上,需要註意的是兩個實體的結果列綁定都需要綁定ProductId屬性,這樣就可以確保存儲過程返回的產品自動創建的ProductId列的值映射到實體的ProductId屬性上。

TPH繼承可以通過執行插入的存儲過程,把ProductType值插入到表中, EF能根據ProductType值,正確地實體化出派生實體.

接下來的Listing 10-27 代碼演示了插入、更新、刪除和查詢.

Listing 10-27. Exercising the Insert, Update, and Delete Actions

    class Program

    {

        static void Main(string[] args)

        {

            using (var context = new EFRecipesEntities1010())

            {

                var book1 = new Book

                {

                    Title = "A Day in the Life",

                    Publisher = "Colorful Press"

                };

                var book2 = new Book

                {

                    Title = "Spring in October",

                    Publisher = "AnimalCover Press"

                };

 

                var dvd1 = new DVD { Title = "Saving Sergeant Pepper", Rating = "G" };

                var dvd2 = new DVD { Title = "Around The Block", Rating = "PG-13" };

                context.Products.Add(book1);

                context.Products.Add(book2);

                context.Products.Add(dvd1);

                context.Products.Add(dvd2);

                context.SaveChanges();

                // update a book and delete a dvd

                book1.Title = "A Day in the Life of Sergeant Pepper";

                context.Products.Remove(dvd2);

                context.SaveChanges();

            }

            using (var context = new EFRecipesEntities1010())

            {

                Console.WriteLine("All Products");

                Console.WriteLine("============");

                foreach (var product in context.Products)

                {

                    if (product is Book)

                        Console.WriteLine("'{0}' published by {1}",

                        product.Title, ((Book)product).Publisher);

                    else if (product is DVD)

                        Console.WriteLine("'{0}' is rated {1}",

                        product.Title, ((DVD)product).Rating);

                }

            }

            Console.WriteLine("\npress any key to exit...");

            Console.ReadKey();

 

        }

}

輸出結果如下麵的 Listing 10-27所示:


 

All Products

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

'Spring in October' published by AnimalCover Press

'A Day in the Life of Sergeant Pepper' published by Colorful Press

'Saving Sergeant Pepper' is rated G 


 

 

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

 


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

-Advertisement-
Play Games
更多相關文章
  • 1.修改主機名及hosts文件10.205.22.185 nn1 (主)作用namenode,resourcemanager,datanode,zk,hive,sqoop10.205.22.186 nn2 (備)作用namenode,resourcemanager,datanode,zk10.205...
  • BBB 的板上有五個 LED 燈,一個電源,四個其他指示燈,usr0 至 usr3 。這次學習是控制 usr0 至 3 讓它們亮著,熄滅,閃。算是個 Hello World 實驗。非常簡單。 需要的材料: BBB 一臺 購買BBB 自帶的數據線一條 手提電腦或台式電腦,有 USB 插頭的 首先用數據...
  • 由於Python易學、開源、面向對象、可移植性高、庫豐富的特點,近期開始學習Python。百度瞭解了各款Python IDE後,還是認為Eric比較適合我,所以踏上了安裝Eric坎坷之路,從選定工具到安裝成功一共花費了8天時間,從Windows到Linux再到Mac,挨個折騰了一遍,Windows的...
  • 問題一:什麼是C#?C#是微軟公司在2000年新推出的一款運行在.NET Framework平臺上面的編程語言,這個.NET Framework平臺又怎麼去理解呢?舉個例子來說好了,一個土著族人只會說土著話,他跑到美國去用土著話跟別人交流,別人當然什麼都聽不懂,最後他還是乖乖回到他的土著國。那麼在這...
  • 此文主要分享瞭如何將自己博客園的文章自動導出到 Markdown 文檔進行存儲,以便在本地進行歸檔管理,程式中也對文章的分類、tag、代碼塊以及文章中的圖片進行了保存處理,以便上傳到自己的圖床。
  • 第11章函數函數提供了一個有力代碼復用機制, 並且讓你的代碼保持簡潔和易懂。它們同樣也是EF運行時能利用的資料庫層代碼.函數有幾類: Rowset Functions, 聚合函數, Ranking Functions, 和標量值函數.函數要麼確定,要麼不確定。當用一些指定的值調用函數,而函數返回的結...
  • 主要介紹什麼是.NET反射特性,.NET反射能為我們做些什麼,最後介紹幾種常用的反射的實現方法,通過對反射性特的瞭解,可以設計出非常有用的基於反射的編程模式。
  • 畢業設計做了一個簡單的研究下驗證碼識別的問題,並沒有深入的研究,設計圖形圖像的東西,水很深,神經網路,機器學習,都很難。這次只是在傳統的方式下分析了一次。今年工作之後再也沒有整理過,前幾天一個家伙要這個demo看下,我把一堆東西收集,打包給他了,他閑太亂了,我就整理記錄下。這也是大學最後的一次...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...