前言
Entity Framework的全稱是ADO.NET Entity Framework,是微軟開發的基於ADO.NET的ORM(Object/Relational Mapping)框架。
Entity Framework的主要特點:
1. 支持多種數據庫(Microsoft SQL Server, Oracle, and DB2);
2. 強勁的映射引擎,能很好地支持存儲過程;
3. 提供Visual Studio集成工具,進行可視化操作;
4. 能夠與ASP.NET, WPF, WCF, WCF Data Services進行很好的集成。
思考?有EF我們就不用自己寫SQL語句了,EF到底做了哪些事情了,我們來探索一下?
我們知道edmx文件是EF的元數據那么我們用XML方式打開EDMX文件可以看到如下所示數據:
圖中的SSDL就表示數據庫的配置節點,CSDL實體配置節點,C-S實體和數據庫的關系映射。
我們發現SSDL配置節點中的GroupInfo節點XML數據和我們數據中的數據完成符合。如下圖
SSDL就表示數據庫的配置節點中的GroupInfo
CSDL實體配置節點中的GroupInfo
C-S實體和數據庫的關系映射中的GroupInfo
了解了這些,那么我們看看EF到底是怎么生成SQL的
private void button1_Click(object sender, EventArgs e) { //1.0 實例化EF上下文容器類的對象 PhoneBookEntities db = new PhoneBookEntities(); //2.0 查詢GropuINfo中的ID<209所有數據 db.GroupInfo.Where(c => c.GroupId < 209).ToList().ForEach(c => Console.WriteLine(c.GroupName)); }
從上圖中的代碼和分析圖我們可以看出:
1.EF緊緊是做了一層包裝,最終還是要在底層調用Ado.NET
2.EF只是負責生成SQL語句,發送給Ado.NET,Ado.NET負責從DB中讀取數據,最終返回給我們的EF
3.EF中edmx元數據獲取DB表的結構的描述
4.我們要生成的查詢SQL語句 select GroupId,GroupName,GroupType from GroupInfo這些可以從元數據中獲取where之后的條件可以由我們的c => c.GroupId < 209提供
由此EF的神秘面紗被我們揭開~~~