Entity Framework 教程——DBContext

来源:http://www.cnblogs.com/Inspire-Yi/archive/2016/12/29/6230567.html
-Advertisement-
Play Games

DBContext: 在之前的章節《創建實體數據模型》中,EDM為我們創建了SchoolDBEntities 類,它派生子System.Data.Entity.DbContext這個類,這個DbContext在EF中被稱作上下文類。 在EF4.1之前,EDM生成的上下文類是派生自ObjectCont ...


DBContext:

在之前的章節《創建實體數據模型》中,EDM為我們創建了SchoolDBEntities 類,它派生子System.Data.Entity.DbContext這個類,這個DbContext在EF中被稱作上下文類。

在EF4.1之前,EDM生成的上下文類是派生自ObjectContext這個類的。它有點難於使用。DbContext 在概念上類似於ObjectContext。DbContext 只是對ObjectContext 進行了封裝使其更容易在所有開發場景中使用。(如Code First, Model First 和 Database First 中)

DbContext 是EF中重要的一環,它是資料庫與你應用程式域或實體類的橋梁。

DbContext 是負責數據與對象互操作的主要的類型。它主要負責以下一些動作:

EntitySet : DbContext 包含所有從資料庫表中被映射出來的實體對象的集合(如DbSet<TEntity>)。

Querying : DbContext 將LINQ To Entities 轉化為SQL 查詢語句併發送至資料庫。

Change Tracking : 它保持變更追蹤,一旦實體對象發生改變它就會從資料庫中進行查詢。

Persisting Data : 它也可以基於實體狀態對資料庫進行插入,更新和刪除操作。

Caching : DbContext 預設作一級緩存,它存儲在上下文類的生命周期中檢索過的實體對象。

Manage Relationship : 在DB-First 或 Model-First 中 DbContext 使用CSDL, MSL 和 SSDL 管理關係,在Code-First中使用流式API管理關係。

Object Materialization : DbContext 將原始的表數據轉化至實體對象中。

以下例子中的SchoolDBEntities 類是又EDM根據SchoolDB資料庫創建的

 1 namespace EFTutorials
 2 {
 3     using System;
 4     using System.Data.Entity;
 5     using System.Data.Entity.Infrastructure;
 6     using System.Data.Entity.Core.Objects;
 7     using System.Linq;
 8     
 9     public partial class SchoolDBEntities : DbContext
10     {
11         public SchoolDBEntities()
12             : base("name=SchoolDBEntities")
13         {
14         }
15     
16         protected override void OnModelCreating(DbModelBuilder modelBuilder)
17         {
18             throw new UnintentionalCodeFirstException();
19         }
20     
21         public virtual DbSet<Course> Courses { get; set; }
22         public virtual DbSet<Standard> Standards { get; set; }
23         public virtual DbSet<Student> Students { get; set; }
24         public virtual DbSet<StudentAddress> StudentAddresses { get; set; }
25         public virtual DbSet<Teacher> Teachers { get; set; }
26         public virtual DbSet<View_StudentCourse> View_StudentCourse { get; set; }
27     
28         public virtual ObjectResult<GetCoursesByStudentId_Result> GetCoursesByStudentId(Nullable<int> studentId)
29         {
30             var studentIdParameter = studentId.HasValue ?
31                 new ObjectParameter("StudentId", studentId) :
32                 new ObjectParameter("StudentId", typeof(int));
33     
34             return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction<GetCoursesByStudentId_Result>("GetCoursesByStudentId", studentIdParameter);
35         }
36     
37         public virtual int sp_DeleteStudent(Nullable<int> studentId)
38         {
39             var studentIdParameter = studentId.HasValue ?
40                 new ObjectParameter("StudentId", studentId) :
41                 new ObjectParameter("StudentId", typeof(int));
42     
43             return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction("sp_DeleteStudent", studentIdParameter);
44         }
45     
46         public virtual ObjectResult<Nullable<decimal>> sp_InsertStudentInfo(Nullable<int> standardId, string studentName)
47         {
48             var standardIdParameter = standardId.HasValue ?
49                 new ObjectParameter("StandardId", standardId) :
50                 new ("StandardId", typeof(int));
51     
52             var studentNameParameter = studentName != null ?
53                 new ObjectParameter("StudentName", studentName) :
54                 new ObjectParameter("StudentName", typeof(string));
55     
56             return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction<Nullable<decimal>>("sp_InsertStudentInfo", standardIdParameter, studentNameParameter);
57         }
58     
59         public virtual int sp_UpdateStudent(Nullable<int> studentId, Nullable<int> standardId, string studentName)
60         {
61             var studentIdParameter = studentId.HasValue ?
62                 new ObjectParameter("StudentId", studentId) :
63                 new ObjectParameter("StudentId", typeof(int));
64     
65             var standardIdParameter = standardId.HasValue ?
66                 new ObjectParameter("StandardId", standardId) :
67                 new ObjectParameter("StandardId", typeof(int));
68     
69             var studentNameParameter = studentName != null ?
70                 new ObjectParameter("StudentName", studentName) :
71                 new ObjectParameter("StudentName", typeof(string));
72     
73             return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction("sp_UpdateStudent", studentIdParameter, standardIdParameter, studentNameParameter);
74         }
75     }
76 }                
View Code

你可以通過上面的例子看出context 類包含類型為DbSet<TEntity>的所有實體集合。也包含EDM中存儲過程及視圖所對應的函數。

Context 類重寫了 OnModelCreating 方法,參數DbModelBuilder 提供流式API來配置Code-First中實體的關係。

實例化 DbContext:

實例化DbContext 來執行CRUD操作。

1             
2 using (var ctx = new SchoolDBEntities())
3 {
4         
5     //在這裡執行CRUD操作..
6 }
7      
View Code

從DbContext 中獲取ObjectContext :

在常見的任務中DBContext 中的API 相較於ObjectContext 的API 而言更加容易使用。當然你也可以從DBContext 中獲取ObjectContext 的引用來使用其中的一些方法。可以同過IObjectContextAdpter 來完成。

1            
2 using (var ctx = new SchoolDBEntities())
3 {
4     var objectContext = (ctx as System.Data.Entity.Infrastructure.IObjectContextAdapter).ObjectContext;
5         
6     //在這裡使用objectContext..
7 }
8       
View Code

 


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

-Advertisement-
Play Games
更多相關文章
  • 我是用U盤裝的centos,在進行硬碟規劃時,看到硬碟的可用空間太少 這是因為我的硬碟以前裝的是windows系統,硬碟幾乎都已經被windows 操作系統給使用了,剩餘空間也只會是windows用剩下那2m空間。網上有好多人說在windows下格式化一個盤就行,我用PE軟體直接格式化了C盤(不想用 ...
  • RHEL 7 with NetworkManager With nmcli, create a new connection of the VLAN type where con-name is the name of the connection, ifname is the name of th ...
  • 今天在阿裡雲上買了一個centos7的伺服器,連接上以後,發現一個很長很長的主機名,看著讓人很是不爽,就想著怎樣將其改成一個有個性的名字。 這裡我想說的是,在centos7 版本的linux系統上和centos6上的修改主機名的方法不一樣,希望大家以後百度的時候,要帶上版本號。本人是查了好多文 章, ...
  • 最近公司有一個幾千萬行的大表需要按照城市的id欄位拆分成不同的csv文件。 寫了一個自動化的shell腳本 在/home/hdh 下麵 linux-xud0:/home/hdh # lltotal 16-rwxrwxrwx 1 root root 902 Dec 28 07:47 cf.sh-rwx ...
  • 工作用到文件上傳的功能,在這個分享下 ~~ Controller: view: 文件是上傳到wwwroot目錄文件下的,這我也看不太懂還在學習,歡迎大家交流~~ 下麵是jquery ajax方式上傳的 post方式的action的z參數沒用 因為只有一個post方式的會404錯誤所以又加了一個get ...
  • 有許多耗時操作時,還要響應用戶操作。這時候就需要用其他線程或者非同步來搞。本來是改造公司的日誌組件。因為多上了個國外大區的業務到來本系統來。這個系統其他地方都好就是日誌,動不動就要死給我們看。有時候尋找業務流程時缺失了一塊日誌,令人欲仙欲死。剛好年末了沒什麼業務上線,決定改造日誌。前人栽樹後人心涼。本 ...
  • 緩存存儲在文件中,根據過期時間過期,也可以手動刪除。IIS回收進程時緩存不丟失。 代碼: using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Security ...
  • Entity Framework中的實體類型 : 在之前的章節中我們介紹過從已有的資料庫中創建EDM,它包含資料庫中每個表所對應的實體。在EF 5.0/6.0中,存在POCO 實體和動態代理實體兩種。 POCO Entity (Plain Old CLR Object): POCO類是不依賴任何框架 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...