博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ADO.NET Entity Framework 学习(1)
阅读量:5266 次
发布时间:2019-06-14

本文共 1826 字,大约阅读时间需要 6 分钟。

前一段时间园子里有很多文章介绍分析了Linq To SQL,它可以说是一个简单实现的ORM,是微软针对数据和对象的阻抗不平衡的问题。C# 3.0推出一些新的特性,比如Extension Method, Lambda Expression, Anonymous Type,其实这些新特性都是用来为Linq服务。Linq To SQL将程序员从以往写大量的sql查询语句、取值、赋值中解放出来,在intellisense和编译上做了很多工作,使得这些查询能够在编译期进行检查。同时微软推出ADO.NET Entity Framework,即下一代的ADO.NET。它是比Linq To SQL更加强大的ORM,让开发人员只需要着眼于领域对象模型的开发,而不需要考虑它们是如何与关系数据库交互。

  本文由一个简单的例子进行介绍Entity Framework是如何使用的。在此之前,必须下载 和,官方也提供了很多下载。下面正式开始ADO.NET Entity Framework之旅(开发工具VS 2008 beta,以Northiwind数据库为例)。

  首先建立一个Console project(要选择.NET Framework 3.5),然后点击Add New Item,看见ADO.NET Entity Data Model选项:

 

然后会出现Wizard,选择数据库,选择表、视图、存储过程等,按照向导一步步来就可以了,在这里只选择Customers和Orders表。在Solution Explore视图里面点击Northwind.edmx,可以看到Entity的信息(看上去很像Linq To SQL的dbml设计视图),然后将它们改名为Customer和Order。

  现在我们就可以进行查询了,先引用命名空间:

using System.Data.Objects;using NorthwindModel;
首先我们查询所有的Customer,代码和Linq To SQL中的十分相似。
using (NorthwindEntities ctx = new NorthwindEntities()) {     foreach (var customer in ctx.Customers)     {         Console.WriteLine(customer.CustomerID);     } }

接着来查询某个Customer,

Customer alfki = ctx.Customers.Where("it.CustomerID = 'ALFKI'").First();

"it.CustomerID = 'ALFKI'"表示查询条件语句,该语句看着又像C#代码又像SQL,被成为Entity SQL Language,具体语法在帮助文档上有很详细的Reference。

这里也可以使用Linq进行查询(Linq To Entities),需要引用System.Linq命名空间,似乎Entity Framework不支持Single方法,会抛出异常。

Customer alfki = ctx.Customers.First
(it => it.CustomerID == "ALFKI");
或者
Customer alfki = (from c in ctx.Customers                  where c.CustomerID == "ALFKIA"                  select c).First();
在Entity Framework中进行一对多的查询很简单,但是值得注意的是Entity Framework默认是Lazy Load,即关联数据在需要的时候才加载。
在本例子中,如果直接查询该Customer关联的orders,查询不到结果。
foreach (var order in alfki.Orders) {     Console.WriteLine(order.OrderID); }

需要在使用orders之前调用 alfki.Orders.Load(), 再次运行便可以得到正确的结果。

转载于:https://www.cnblogs.com/zwb7926/archive/2013/06/03/3115674.html

你可能感兴趣的文章
C# Dynamic通用反序列化Json类型并遍历属性比较
查看>>
exit和return的区别
查看>>
Python(软件目录结构规范)
查看>>
c++||template
查看>>
条件断点 符号断点
查看>>
Dreamweaver cc新版本css单行显示
查看>>
Java基础教程——网络基础知识
查看>>
Kruskal基础最小生成树
查看>>
【hdu 1429】胜利大逃亡(续)
查看>>
javascript之Style物
查看>>
Factory Design Pattern
查看>>
P1192-台阶问题
查看>>
Java大数——a^b + b^a
查看>>
简单的数据库操作
查看>>
帧的最小长度 CSMA/CD
查看>>
树状数组及其他特别简单的扩展
查看>>
普通求素数和线性筛素数
查看>>
PHP截取中英文混合字符
查看>>
【洛谷P1816 忠诚】线段树
查看>>
电子眼抓拍大解密
查看>>