EntityFramework是什么?

1.是对ADO.NET 更高封装的ORM (对象关系映射)框架,跟Nhibernate类似

2.用面向对象的方式来操作关系数据库

3.目标: 提高开发效率,减轻维护工作

4.原理

LINQ to Entities 和 Entity SQL : EF 的两种查询语言,前者用Linq 方式查询,后者用SQL方言(比较少用)

Object Service : 将 Entity Client Data Provider 返回的数据 转换成 实体对象结构

Entity Client Data Provider : 主要作用是将 LINQ to Entities 和 Entity SQ 这些查询转换为 数据库的SQL查询

ADO.Net Data Provider : 执行 Entity Client Data Provider 生成的数据库SQL

总结 :  面向对象查询--> 通过EF ->生成相应数据库SQL --> ADO.NET 执行

怎么用?

1 . 生成实体框架模型

右击项目->添加->新建项->ADO.NET 实体数据模型->添加-  >下一步->新建连接或者使用已有连接->

选择保存敏感数据->下一步->选择要映射的表,存储过程或者其他对象->完成

2 .增删改查

    static void Main(string[] args)
{
using (AnuoDogEntities1 db = new AnuoDogEntities1())
{
//增加
UserInfo uf = new UserInfo();
uf.UserName = "anuo";
uf.PassWord = "";
uf.Address = "成都";
db.AddToUserInfo(uf);
db.SaveChanges(); //删除
UserInfo ufd = db.UserInfo.FirstOrDefault(ee => ee.UserName == "anuo");
db.DeleteObject(ufd);
db.SaveChanges(); //修改
UserInfo ufx = db.UserInfo.FirstOrDefault(ee => ee.UserName == "anuo");
ufx.UserName = "anuodog";
db.SaveChanges(); //查询 LINQ to Entities
var data =
from userInfo in db.UserInfo
where userInfo.UserName == "anuo"
select new
{
userName = userInfo.UserName,
password = userInfo.PassWord };
string name = "";
foreach (var item in data)
{
name += item.userName;
} //表连接查询(左连接)
var query =
from userInfo in db.UserInfo
join productInfo in db.ProductInfo
on userInfo.Id equals productInfo.UserId
select new
{
userName = userInfo.UserName,
productName = productInfo.ProductName
};
}
}

应用场景?

优点 : 开发效率高,适合简单数据操作

缺点 : 性能低 , 不适合复杂数据操作

怎么个性能低?

比原生的ADO.NET 确实慢得多. 适合小数据简单操作

原文链接 :

http://blogs.msdn.com/b/adonet/archive/2012/02/14/sneak-preview-entity-framework-5-0-performance-improvements.aspx

开发模式?

Database First  数据库首先 : 先设计好数据库 ,再从数据库生成实体模型

Model First  模型优先 : 先设计好模型 ,再从模型生成数据库

Code First  代码优先 : 编好代码,再从代码生成或映射数据库

资源?

入门: http://www.cnblogs.com/xray2005/category/189491.html

教程: http://www.entityframeworktutorial.net/

MSDN:

http://msdn.microsoft.com/zh-cn/library/bb399572(v=vs.100).aspx

主页: http://msdn.microsoft.com/zh-CN/data/ef

源码: https://github.com/aspnet/EntityFramework

团队blog:  http://blogs.msdn.com/b/adonet/

EntityFramework简介的更多相关文章

  1. Entity Framework 一

    本篇主要介绍:EntityFramework简介, 实体框架架构图, EF版本 实体框架: 编写和管理数据访问的ADO.Net代码是一件单调乏味的工作.微软已经提供了一个名为“实体框架”的O / RM ...

  2. 五:MVC使用数据库优先(DatabaseFirst)的方式创建数据模型

    1. ORM概念 2. EF的DatabaseFirst模式使用 1. ORM简介 对象关系映射(Object Relational Mapping,简称ORM) ORM技术特点: 1.提高了开发效率 ...

  3. Webservice WCF WebApi 前端数据可视化 前端数据可视化 C# asp.net PhoneGap html5 C# Where 网站分布式开发简介 EntityFramework Core依赖注入上下文方式不同造成内存泄漏了解一下? SQL Server之深入理解STUFF 你必须知道的EntityFramework 6.x和EntityFramework Cor

    Webservice WCF WebApi   注明:改编加组合 在.net平台下,有大量的技术让你创建一个HTTP服务,像Web Service,WCF,现在又出了Web API.在.net平台下, ...

  4. ASP.NET Core 1.1 Preview 1 简介(包含.NETCore 1.1升级公告)

    ASP.NET Core 1.1 Preview 1于2016年10月25日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强. 要将现有项目更新到ASP.NET Core 1.1 Pre ...

  5. Asp.Net Core 项目实战之权限管理系统(3) 通过EntityFramework Core使用PostgreSQL

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  6. 【无私分享:ASP.NET CORE 项目实战(第三章)】EntityFramework下领域驱动设计的应用

    目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 在我们 [无私分享:从入门到精通ASP.NET MVC] 系列中,我们其实也是有DDD思想的,但是没有完全的去实现,因为并不是 ...

  7. 解读ASP.NET 5 & MVC6系列(1):ASP.NET 5简介

    ASP.NET 5简介 ASP.NET 5是一个跨时代的改写,所有的功能和模块都进行了独立拆分,做到了彻底解耦.为了这些改写,微软也是蛮 拼的,几乎把.NET Framwrok全部改写了一遍,形成了一 ...

  8. ASP.NET Core 1.1 静态文件、路由、自定义中间件、身份验证简介

    概述 之前写过一篇关于<ASP.NET Core 1.0 静态文件.路由.自定义中间件.身份验证简介>的文章,主要介绍了ASP.NET Core中StaticFile.Middleware ...

  9. ASP.NET Core 1.0 静态文件、路由、自定义中间件、身份验证简介

    概述 ASP.NET Core 1.0是ASP.NET的一个重要的重新设计. 例如,在ASP.NET Core中,使用Middleware编写请求管道. ASP.NET Core中间件对HttpCon ...

随机推荐

  1. Windows 10 技术预览版9926 “未知源”引起系统休眠后自启的解决办法

    问题的由来: 自从安装上了最新发布的Windows 10 ,使用起来有诸多的改进:无论是重绘的图标还是通知消息中心的整合还是更智能的OneDrive客户端都使得工作起来非常愉悦. 不过笔者这两天频繁遇 ...

  2. .net基本数据类型操作

    代码编写的过程中,较多的会涉及到基本数据类型的使用和定义,在项目中,对于类型的判定和类型间的相互转换,有时也较为的麻烦,先提供几种基本数据类型的判断方法: 1.判断对象是否为Int32类型的数字: / ...

  3. lamp 环境搭建

    LAMP指的Linux(操作系统).ApacheHTTP 服务器,MySQL(数据库软件)和PHP语言 使用wampserver软件,搭建环境.如下图: 双击程序包,安装最后一步随便选择一个浏览器打开 ...

  4. 函数----Beginning Visual C#

    span.kw { color: #007020; font-weight: bold; } code > span.dt { color: #902000; } code > span. ...

  5. Linux中mongodb安装和导出为json

    采用官方工具导出mongo数据为json格式 文档:https://docs.mongodb.com/manual/reference/program/mongoexport/ 可以远程导出,只要有h ...

  6. SqlServer 分页查询

    1.not in方法 select top 10 from books where id not in (select top 30 id from books)   2.row_number()函数 ...

  7. 关系数据库SQL之可编程性事务

    前言 前面关系数据库SQL之可编程性函数(用户自定义函数)一文提到关系型数据库提供了可编程性的函数.存储过程.事务.触发器及游标,前文已介绍了函数.存储过程,本文来介绍一下事务的使用.(还是以前面的银 ...

  8. SQL Server 存储过程遇到“表 '#TT' 没有标识属性。无法执行 SET 操作”错误

    创建临时表,往临时表插入数据的时候报的错误. 一开始提示没有打开主键,后来打开主键就提示上述错误异常. 从网上查找资料没有找到,然后又到群里问各位大牛,一位大牛告诉我是没有设置主键. 我又仔细看看提示 ...

  9. 使用EncryptByPassPhrase和DecryptByPassPhrase对MS SQLServer某一字段时行加密和解密

    在数据库实现加密与解密的文章,Insus.NET较早前也有写过,可以在本博客中可以搜索得到. 今天使用EncryptByPassPhrase和DecryptByPassPhrase来简单实现. 在数据 ...

  10. 异构(兼容dubbo)SOA系统架构(.net)优化升级

    前面一片文章已经提到我司的异构(兼容dubbo)SOA系统架构,解决了不少技术痛点,也还算比较完善,也顺利推广开来. 但作为项目的开发者,自己产品的问题心里是清楚的,离自己满意还是有不小的距离. 在推 ...