Entity Framework 6 Recipes 2nd Edition(10-9)譯 -> 在多對多關係中為插入和刪除使用存儲過程

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

10-9. 在多對多關係中為插入和刪除使用存儲過程問題想要在一個無載荷的多對多關係中使用存儲過程(存儲過程隻影響關係的連接表)解決方案假設有一個多對多關係的作者( Author)表和書籍( Book)表. 用連接表AuthorBook來做多對多關係,如 Figure 10-11.所示:Figure ...


10-9. 在多對多關係中為插入和刪除使用存儲過程

問題

想要在一個無載荷的多對多關係中使用存儲過程(存儲過程隻影響關係的連接表)

解決方案

假設有一個多對多關係的作者( Author)表和書籍( Book)表. 用連接表AuthorBook來做多對多關係,如 Figure 10-11.所示:

 

Figure 10-11. A payload-free, many-to-many relationship between an Author and a Book

當把表生成模型,那麼模型就如Figure 10-12所示:

Figure 10-12. The model created by importing the tables in Figure 10-11

接下來用存儲過程創建插入和刪除操作:

1.在資料庫中,創建如Listing 10-23所示的存儲過程.

Listing 10-23. The stored Procedures for the Insert and Delete Actions

create procedure [chapter10].[InsertAuthorBook]

(@AuthorId int,@BookId int)

as

begin

insert into chapter10.AuthorBook(AuthorId,BookId) values (@AuthorId,@BookId)

end

go

 

create procedure [chapter10].[DeleteAuthorBook]

(@AuthorId int,@BookId int)

as

begin

delete chapter10.AuthorBook where AuthorId = @AuthorId and BookId = @BookId

end

2. 右擊模型設計視圖,選擇“從資料庫中更新模型”,選擇 Listing 10-23所創建的存儲過程,單擊“完成”,這樣就把存儲過程添加到了模型里。

3. 目前版本的EF沒有為一個關係插入和刪除操作映射的設計視圖,只能用手工去映射, 右擊.edmx 文件,選擇“打開方式”,選擇“XML (文本)編輯器”. 在<AssociationSetMapping> 標簽下插入 Listing 10-24所示的代碼(譯註:根據自己的例子命名修改代碼里的)

Listing 10-24. Mapping the Stored Procedures to the Insert and Delete Actions for the Many-to-Many Association

            <ModificationFunctionMapping>

              <InsertFunction FunctionName="EFRecipesModel1009.Store.InsertAuthorBook">

                <EndProperty Name="Author">

                  <ScalarProperty Name="AuthorId" ParameterName="AuthorId" />

                </EndProperty>

                <EndProperty Name="Book">

                  <ScalarProperty Name="BookId" ParameterName="BookId" />

                </EndProperty>

              </InsertFunction>

              <DeleteFunction FunctionName="EFRecipesModel1009.Store.DeleteAuthorBook">

                <EndProperty Name="Author">

                  <ScalarProperty Name="AuthorId" ParameterName="AuthorId" />

                </EndProperty>

                <EndProperty Name="Book">

                  <ScalarProperty Name="BookId" ParameterName="BookId" />

                </EndProperty>

              </DeleteFunction>

            </ModificationFunctionMapping>

接下來Listing 10-25 代碼演示了插入和刪除操作.你可以用Sql Profiler來查看當

InsertAuthorBook 和DeleteAuthorBook 存儲過程被EF在更新多對多關係時調用後生成的SQL語句

Listing 10-25. Inserting into the Model

    class Program

    {

        static void Main(string[] args)

        {

            using (var context = new EFRecipesEntities1009())

            {

                context.Database.ExecuteSqlCommand("delete from chapter10.AuthorBook");

                context.Database.ExecuteSqlCommand("delete from chapter10.book");

                context.Database.ExecuteSqlCommand("delete from chapter10.Author");

 

                var auth1 = new Author { Name = "Jane Austin" };

                var book1 = new Book

                {

                    Title = "Pride and Prejudice",

                    ISBN = "1848373104"

                };

                var book2 = new Book

                {

                    Title = "Sense and Sensibility",

                    ISBN = "1440469563"

                };

                auth1.Books.Add(book1);

                auth1.Books.Add(book2);

                var auth2 = new Author { Name = "Audrey Niffenegger" };

                var book3 = new Book

                {

                    Title = "The Time Traveler's Wife",

                    ISBN = "015602943X"

                };

                auth2.Books.Add(book3);

                context.Authors.Add(auth1);

                context.Authors.Add(auth2);

                context.SaveChanges();

                context.Books.Remove(book1);

                context.SaveChanges();

            }

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

            Console.ReadKey();

 

        }

}

SQL Profiler里跟蹤到的SQL語句如下(Listing 10-25)所示:

exec sp_executesql N'insert [Chapter10].[Author]([Name])values (@0)

select [AuthorId] from [Chapter10].[Author]

where @@ROWCOUNT > 0 and [AuthorId] = scope_identity()',N'@0 varchar(50)',@0='Jane Austin'

 

exec sp_executesql N'insert [Chapter10].[Author]([Name])values (@0)

select [AuthorId] from [Chapter10].[Author]

where @@ROWCOUNT > 0 and [AuthorId] = scope_identity()',N'@0 varchar(50)',

@0='Audrey Niffenegger'

 

exec sp_executesql N'insert [Chapter10].[Book]([Title], [ISBN])values (@0, @1)

select [BookId]    from [Chapter10].[Book]

where @@ROWCOUNT > 0 and [BookId] = scope_identity()',N'@0 varchar(50),

@1 varchar(50)',@0='Pride and Prejudice',@1='1848373104'

 

exec sp_executesql N'insert [Chapter10].[Book]([Title], [ISBN])values (@0, @1)

select [BookId] from [Chapter10].[Book]

where @@ROWCOUNT > 0 and [BookId] = scope_identity()',N'@0 varchar(50),

@1 varchar(50)',@0='Sense and Sensibility',@1='1440469563'

 

exec sp_executesql N'insert [Chapter10].[Book]([Title], [ISBN])values (@0, @1)

select [BookId]  from [Chapter10].[Book]

where @@ROWCOUNT > 0 and [BookId] = scope_identity()',N'@0 varchar(50),

@1 varchar(50)',@0='The Time Traveler''s Wife',@1='015602943X'

 

exec [Chapter10].[InsertAuthorBook] @AuthorId=1,@BookId=1

exec [Chapter10].[InsertAuthorBook] @AuthorId=1,@BookId=2

exec [Chapter10].[InsertAuthorBook] @AuthorId=2,@BookId=3

 

exec [Chapter10].[DeleteAuthorBook] @AuthorId=1,@BookId=1

exec sp_executesql N'delete [Chapter10].[Book] where ([BookId] = @0)',N'@0 int',@0=1

它是如何工作的?

為把存儲過程映射到多對多關係中的插入和刪除操作, 我們在資料庫中創建存儲過程,然後用存儲過程模型.由於EF設計視圖不支持關係型的模型映射插入和刪除操作,我們需要用XML編輯器直接打開.edmx 文件, 在Mappings 節點里 <ModificationFunctionMapping> 標簽下,我們添加了插入和刪除操作映射到存儲過程的代碼。

從Listing 10-25跟蹤生成的SQL,我們可以看到,不只是插入或刪除 Author 和 Book 兩個表, 同時我們也可以看到,存儲過程在關係模型中插入和刪除操作時被使用。

 

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

 


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

-Advertisement-
Play Games
更多相關文章
  • linux下掛載(mount)光碟映像文檔、移動硬碟、U盤、Windows和NFS網路共用. linux是個優秀的開放源碼的操作系統,能夠運行在大到巨型小到掌上型各類電腦系統上,隨著linux系統的日漸成熟和穩定連同他開放源代碼特有的優越 性,linux在全世界得到了越來越廣泛的應用。現在許多企業....
  • 我不是創客。我買了個 Beaglebone Black 來玩,主要是拿來學習。 入手前,看過好幾個樹莓派 (Raspi - 2 Model B)和 Beaglebone Black (BBB) 比較,網上很多都是翻譯自某一篇國外博文。事實上用起來之後,看了一點 BBB 的書之後,兩者的區別似乎不止博...
  • 玩玩mysql最新版本,體驗源碼安裝,教你進行主從配置,實現讀寫分離
  • 一、簡介 GitLab是利用 Ruby on Rails 一個開源的版本管理系統,實現一個自托管的Git項目倉庫,可通過Web界面進行訪問公開的或者私人項目。它擁有與Github類似的功能,能夠瀏覽源代碼,管理缺陷和註釋。可以管理團隊對倉庫的訪問,它非常易於瀏覽提交過的版本並提供一個文件歷史庫。團隊...
  • 該隨筆為個人原創,後期會根據項目實踐實時更新,如若轉載,請註明出處,方便大家獲得最新博文!註:安裝Nginx需要Linux系統已經安裝openssl-fips-2.0.2.tar.gzzlib-1.2.7.tar.gzpcre-8.21.tar.gz第一步:從http://nginx.org/dow...
  • 1、配置redis master,redis slave(配置具體操作見上文http://www.cnblogs.com/wangchaozhi/p/5140469.html)。redis master ip:127.0.0.1:port 6379(預設配置文件即可)redis slave1 ip:...
  • 作為一個網站開發者,使用asp.net開髮網站,由於添加功能模塊不便利,所以我開始學習mvc框架。 今天是我學習mvc框架的第一天,首先就是連接EF連接資料庫(Sql Server2012資料庫),下麵我使用圖片和文字來描述我的過程。1.首先創建控制台應用程式(使用的框架是4.5),然後再控制...
  • https://ajaxcontroltoolkit.codeplex.com/警告 7 未能找到引用的組件“Antlr3.Runtime”。 警告 6 未能找到引用的組件“HtmlAgilityPack”。 警告 10 未能找到引用的組件“HtmlAgilityPack”。 警告 1 未能找到引用...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...