天天看點

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  之前的文章中介紹了如何在ASP.NET中通過ADO.NET操作SQL Server和My SQL資料庫,資料庫的操作是通過SQL語句的執行來完成的,在ASP.NET中還有一個簡便的方式來使用資料庫,那就是通過Entity Framework這個ORM元件。EF操作資料的原理也是最終生成SQL來執行。

  本文将從以下幾個方面來完成Entity Framework的介紹:

  ●什麼是ORM

  ●Entity Framework

  ●使用EF Code First操作資料庫

  對象關系映射(Object Relational Mapping,簡稱ORM,或O/RM,或O/R mapping),是一種程式技術,用于實作面向對象程式設計語言裡不同類型系統的資料之間的轉換。(百度百科)。

  Object-relational mapping (ORM, O/RM, and O/R mapping tool) in computer science is a programming technique for converting data between incompatible type systems using object-oriented programming languages.(wikipedia)

  以上兩個解釋的核心點都在于“面向對象”、“不同類型系統”、“資料轉換”,對于使用ASP.NET MVC開發的應用程式來說,開發語言C#就是一個面向對象程式設計語言,定義的實體類Post就是一個失血模型(隻有屬性沒有方法)對象。而資料庫系統與部落格系統是兩個不同的系統,對于資料庫系統來說它将資料看成由數字或字元串構成的一張張表格,而面向對象語言所開發的程式将資料看作一個個執行個體,表格資料和執行個體資料是不相容的,是以需要轉換,如之前的代碼:

  

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  在之前的代碼中,通過自己編寫代碼的方式完成了轉換,既然ORM是一種程式技術,那麼在ASP.NET中是如何展現的呢?

  Entity Framework(EF)是一個對象關系映射器,它讓.Net開發人員可以使用領域對象來操作關系資料,并幫助開發人員省略大部分通路資料的代碼。

如何使用Entity Framework?

  在介紹如何使用EF之前,先了解一下EF的幾種工作流,它們如下圖所示:

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  ● 模型優先(建立一個新的資料庫):

    ○ 在設計器中建立模型。

    ○ 通過模型建立資料庫。

    ○ 通過模型自動生成實體類。

  ● 資料庫優先(使用已存在的資料庫):

    ○ 在設計器中反向工程模型。

  ● 代碼優先(新資料庫):

    ○ 在代碼中定義實體類和映射(如類和表的映射、屬性和表列的映射)。

    ○ 使用Migrations去更新資料庫(結構)。

  ● 代碼優先(使用已存在資料庫):

    ○ 或者使用反向工程生成實體類和映射。

  對于本系列文章僅對代碼優先(Code First)做介紹(*^_^*)/

  現在Blog代碼中已經存在實體類并且已經存在資料庫和對應的資料表,是以不需要再建立。

  1. 通過Nuget擷取Entity Framework庫:

  因為BlogRepository是管理資料存儲的庫,是以應該将EntityFramework安裝到該項目上:

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  2. 建立DBContext類型:

  DBContext是EF中的核心類型,EF中的從資料庫擷取資料填充到實體對象、變化跟蹤以及将資料持久化到資料庫都是有DBContext完成的。而建立一個DBContext最常用的方法就是繼承DbContext類型來實作,DbContext類型位于EntityFramework程式集下的System.Data.Entity命名空間下:

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM
ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  3. 在實體中添加DbSet屬性:

  DbSet屬性代表指定類型的一個資料集合,所有對資料的添加、删除、修改、查詢都是通過這個屬性實作的。

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  4. 通過構造方法給DbContext指定資料庫連接配接字元串:

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  5. 将BlogRepository替換成BlogContext操作資料庫:

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  注:别忘記添加Linq命名空間來使用對資料集合的操作。

  6. 運作程式(檢視部落格清單頁面):

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  出錯了,錯誤資訊顯示找不到名稱為“System.Data.SqlClient”的ADO.NET提供器,為什麼?

  在使用Nuget安裝EF的時候會自動在Web.config或者App.config中建立一下配置資訊:

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  在本例中EF安裝到了BlogRepository類庫項目上,是以程式在啟動時是無法讀取到這些配置資訊的,但要注意的是錯誤資訊的重點在于“找不到ADO.NET Provider”而不是找不到配置資訊。是以實際上這個問題的根本原因在于安裝EF元件後,預設會添加EntityFramework.dll以及EntityFramework.SqlServer.dll兩個庫檔案的引用,但是由于EF沒有安裝到啟動項目上,是以在項目編譯時隻會複制主項目依賴的程式集,以及被依賴程式集使用到的程式集。就是說BlogRepository隻用到了EntityFramework.dll而沒有使用到EntityFramework.SqlServer.dll是以後者沒有在主項目的bin目錄下,是以僅需要将該程式集複制到MVC項目的bin目錄下即可運作:

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM
ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

  注:EF是基于“約定優先于配置”原則,是以EF的預設約定就是使用SQL SERVER,是以在這裡如果沒有特殊的需求,沒有配置資訊EF也是能夠正常運作的,更多關于EF配置的介紹會在後續章節中完成。

  本章主要介紹了ASP.NET中的ORM架構Entity Framework,并且示範了如何安裝EF、建立DbContext和DbSet并使用它們通路資料庫。使用EF後相比起之前擷取資料庫資料代碼已經少了很多,一句代碼就可以完成資料的擷取功能,大大的提高了開發效率。

  在本文中有一個要注意的問題就是EF是間接被主項目使用的,是以一些與EF有關的功能如更新資料庫(update-database)以及資料庫遷移(migration)指令的使用都會與EF在被主項目直接使用有所差別,關于EF的更多内容将在後續文章中介紹。

參考:

  https://msdn.microsoft.com/en-us/library/aa937723(v=vs.113).aspx

  https://msdn.microsoft.com/en-us/library/ee712907(v=vs.113).aspx

本文位址:http://www.cnblogs.com/selimsong/p/7651602.html 

ASP.NET沒有魔法——目錄

作者:7m魚

出處:http://www.cnblogs.com/selimsong/

本文版權歸作者和部落格園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接配接,否則保留追究法律責任的權利。

ASP.NET沒有魔法——ASP.NET MVC 與資料庫之ORM

繼續閱讀