国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

[原創]EntityFramework查詢原理

2019-11-14 16:09:27
字體:
來源:轉載
供稿:網友

前言

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的神秘面紗被我們揭開~~~


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 寻甸| 花垣县| 乡宁县| 资溪县| 黔西县| 莲花县| 浦北县| 万安县| 塘沽区| 金山区| 衡南县| 武汉市| 新巴尔虎右旗| 赣榆县| 剑河县| 虎林市| 城口县| 三江| 辽阳县| 阜康市| 宜兰县| 鄂托克旗| 那曲县| 文山县| 陆河县| 邹平县| 长乐市| 北票市| 大渡口区| 城市| 定西市| 柳江县| 奉新县| 博罗县| 宁晋县| 安陆市| 漳平市| 抚远县| 乐都县| 邓州市| 珲春市|