概要

Entity Framework缩写EF,微软ORM产品。

本篇博客将简单的介绍它,至于它的详细深层次的使用,大家能够查询对应的操作手冊,该篇不过入门。

Entity Framework和Linq to Sql的关系

大家都知道Linq to Sql是微软ORM思想的一个详细产品。Entity Framework也是它的一个详细产品,那么,这两个产品有什么差别呢?

Linq to Sql是ORM思想实现的一个轻量级的框架,Entity Framework是一个重量级框架;

Linq to Sql和Entity Framework的一个重要的差别就是,Linq to Sql仅仅能针对于SQL Server数据库,而Entity Framework能够针对于非常多的数据库(Oracle,SQL Server等),也就是说Entity Framework是跨数据库的。不要小看这一点,在实际的开发中,非常的牛叉,以下我们举例说明。

我们使用经典三层构建一个项目,我们须要写自己的D层,假设此时我们换了数据库,那么,我们须要重写D层。假设我们在创建这个项目的时候,使用了Linq to Sql,那么我们的D层创建的很的简单,可是,当我们换数据库的时候,Linq to Sql框架就无论用了;假设我们在创建这个项目的时候,使用了Entity Framework框架,那么。我们仅仅须要改一个配置文件就能够了,不须要改动程序中的代码。

为什么使用Linq to Sql或Entity Franework

回答这个问题,我们就要说一说D层存在的问题了。

我们写D层的时候。我们一般会抽象出来一个SQLHelper类,这个类实现了对数据库的增删查改,然后,我们再创建对应的D层类。这些D层类里面的方法的功能,事实上都一样,唯一不同的就是SQL。从这里我们能够看到。我们的D层的问题,那就是,我们反复性的书写一些不必要的类或者方法,解决这种方法就须要慢慢的抽象。抽象出共同拥有的东西,像:DataTable装换为实体集。操作数据库的几类方法(注意其參数),然后将其一整合。这个大致就是我们所属的ORM思想实现的雏形了。当然,上面所说的那些东西。Linq
to Sql或Entity Framework这些框架已经帮助我们实现了,我们仅仅须要使用它们提供的方法即可了,从这里我们也能够看到。假设我们使用这些框架。我们程序猿在编程的时候。差点儿不须要管理D层的东西,仅仅须要关注业务的实现就能够了。

Entity Framework的实例

SQL脚本

CREATE DATABASE DBFirst
GO
USE DBFirst
GO CREATE TABLE T_Customer
(
ID INT PRIMARY KEY IDENTITY(1,1),
CusName VARCHAR(20) NOT NULL
)
CREATE TABLE T_Order
(
ID INT PRIMARY KEY IDENTITY(1,1),
CustomerID INT FOREIGN KEY REFERENCES T_Customer(ID),
DepName VARCHAR(20) NOT NULL
)

程序代码

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamliZW4ycWluZ3NoYW4=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data; namespace EF.EntityFrameworkDemo
{
class Program
{
static void Main(string[] args)
{
#region 加入实体
////创建上下文对象
//DBFirstEntities dbFirst = new DBFirstEntities();
////操作实体
//T_Customer customer = new T_Customer();
//customer.CusName = "新添用户";
////附加在上下文
//dbFirst.T_Customer.AddObject(customer);
////保存
//dbFirst.SaveChanges();
#endregion #region 删除实体
////1、创建上下文对象
//DBFirstEntities dbFirst = new DBFirstEntities();
////2、创建实体
//T_Customer customer = new T_Customer();
//customer.ID = 9;
////3、将实体附加到上下文里面来进行管理
//dbFirst.T_Customer.Attach(customer);
////改动实体的状态
//dbFirst.ObjectStateManager.ChangeObjectState(customer, EntityState.Deleted);
////4、上下文操作数据库
//dbFirst.SaveChanges();
#endregion #region 改动实体
////1、创建訪问数据库的上下文对象
//DBFirstEntities dbFirst = new DBFirstEntities();
////2、改动对象
//T_Customer customer = new T_Customer();
//customer.ID = 4;
//customer.CusName = "用户4_改动后2";
////3、附加到数据库
//dbFirst.T_Customer.AddObject(customer);
////改动对象状态
//dbFirst.ObjectStateManager.ChangeObjectState(customer, EntityState.Modified);
////4、上下文更新数据库
//dbFirst.SaveChanges();
#endregion #region 查询
DBFirstEntities dbFirst = new DBFirstEntities(); foreach (var item in dbFirst.T_Customer)
{
Console.WriteLine(string.Format("ID:{0} Name:{1}",item.ID,item.CusName));
}
#region linq表达式
T_Customer cs = (from customer in dbFirst.T_Customer where customer.ID == 2 select customer).SingleOrDefault();
Console.WriteLine("ID:{0} Name:{1}",cs.ID,cs.CusName);
#endregion #endregion Console.ReadKey();
}
}
}

总结

EF的使用大致能够分为:DBFirst(数据库为中心)和ModelFirst(实体为中心),以上是DBFirst型号。至于ModelFirst。你可以搜索一下。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

Entity Framework基金会的更多相关文章

  1. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第二章:利用模型类创建视图、控制器和数据库

    在这一章中,我们将直接进入项目,并且为产品和分类添加一些基本的模型类.我们将在Entity Framework的代码优先模式下,利用这些模型类创建一个数据库.我们还将学习如何在代码中创建数据库上下文类 ...

  2. Entity Framework Core 1.1 升级通告

    原文地址:https://blogs.msdn.microsoft.com/dotnet/2016/11/16/announcing-entity-framework-core-1-1/ 翻译:杨晓东 ...

  3. Entity Framework Core 实现MySQL 的TimeStamp/RowVersion 并发控制

    将通用的序列号生成器库 从SQL Server迁移到Mysql 遇到的一个问题,就是TimeStamp/RowVersion并发控制类型在非Microsoft SQL Server数据库中的实现.SQ ...

  4. 采用MiniProfiler监控EF与.NET MVC项目(Entity Framework 延伸系列1)

    前言 Entity Framework 延伸系列目录 今天来说说EF与MVC项目的性能检测和监控 首先,先介绍一下今天我们使用的工具吧. MiniProfiler~ 这个东西的介绍如下: MVC Mi ...

  5. 来,给Entity Framework热热身

    先来看一下Entity Framework缓慢的初始化速度给我们更新程序带来的一种痛苦. 我们手动更新程序时通常的操作步骤如下: 1)把Web服务器从负载均衡中摘下来 2)更新程序 3)预热(发出一个 ...

  6. 采用EntityFramework.Extended 对EF进行扩展(Entity Framework 延伸系列2)

    前言 Entity Framework 延伸系列目录 今天我们来讲讲EntityFramework.Extended 首先科普一下这个EntityFramework.Extended是什么,如下: 这 ...

  7. Entity Framework教程(第二版)

    源起 很多年前刚毕业那阵写过一篇关于Entity Framework的文章,没发首页却得到100+的推荐.可能是当时Entity Framework刚刚发布介绍EF的文章比较少.一晃这么多年过去了,E ...

  8. Entity Framework 6 Recipes 2nd Edition 译 -> 目录 -持续更新

    因为看了<Entity Framework 6 Recipes 2nd Edition>这本书前面8章的翻译,感谢china_fucan. 从第九章开始,我是边看边译的,没有通读,加之英语 ...

  9. ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第一章:创建基本的MVC Web站点

    在这一章中,我们将学习如何使用基架快速搭建和运行一个简单的Microsoft ASP.NET MVC Web站点.在我们马上投入学习和编码之前,我们首先了解一些有关ASP.NET MVC和Entity ...

随机推荐

  1. Libev学习笔记1

    和Libevent相似,Libev是一个高性事件驱动框架,据说性能比Libevent要高,bug比Libevent要少.Libev只是一个事件驱动框架,不是网络库,因为它的内部并没有任何socket编 ...

  2. poj 1088 滑雪(区间dp+记忆化搜索)

    题目链接:http://poj.org/problem?id=1088 思路分析: 1>状态定义:状态dp[i][j]表示在位置map[i][j]可以滑雪的最长区域长度: 2>状态转移方程 ...

  3. citrix协议ICA技术原理

    转载自: http://www.zrss.com.cn/article-110-1.html Citrix交付中心解决方式的核心是虚拟化技术,虚拟化计算的核心是ICA协议,ICA协议连接了执行在平台上 ...

  4. ofbiz学习笔记

    最新稳定版apache-ofbiz-13.07.02 最新源码ofbiz-release14.12 ant load-demo 载入演示样例数据 ant load-seed 仅仅载入种子数据 ant ...

  5. MAVEN入门(二)

    一.IDEA+MAVEN+Tomcat7 创建一个简单的Web app 1.用IDEA创建一个maven项目 注意: 红色部分一定要自己手选本地配置好的maven_home的地址,否则IDEA会选用内 ...

  6. URAL 1009 K-based Numbers

    题目:Click here #include <bits/stdc++.h> using namespace std; typedef long long ll; const int IN ...

  7. JBPM6教程

    JBPM6教程-手把手教你安装JBPM 1. 安装JBPM的先决条件: (1)JDK 1.6+以上,没有安装的话,猛击这里. (2)Ant 1.7+以上,没有安装的话,看看这里. 2. 下载JBPM安 ...

  8. KVM镜像管理利器-guestfish使用详解

    原文  http://xiaoli110.blog.51cto.com/1724/1568307   KVM镜像管理利器-guestfish使用详解 本文介绍以下内容: 1. 虚拟机镜像挂载及w2k8 ...

  9. (Problem 57)Square root convergents

    It is possible to show that the square root of two can be expressed as an infinite continued fractio ...

  10. Ubuntu基本设置

    (1)  为了启用 root 帐号 (也就是 设置一个口令) 使用: sudo passwd root 1.设置IP, 终端输入 sudo gedit /etc/network/interfaces ...