国产探花免费观看_亚洲丰满少妇自慰呻吟_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的神秘面紗被我們揭開~~~


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昌宁县| 昭苏县| 赫章县| 九龙坡区| 奈曼旗| 香格里拉县| 普兰店市| 苏尼特左旗| 汪清县| 丰宁| 长汀县| 昆山市| 乌兰察布市| 根河市| 白朗县| 文山县| 双鸭山市| 吉木萨尔县| 岱山县| 和政县| 化州市| 全南县| 嘉义县| 兴城市| 江永县| 三江| 塔城市| 吴桥县| 曲周县| 宁城县| 黄冈市| 沙洋县| 惠来县| 清水河县| 绥棱县| 泸州市| 陆河县| 林芝县| 科技| 伊宁市| 阜平县|