方法1:

  新建好项目之后 → 右击类库 → 新建项 → ADO.NET实体数据模型(在Visual C#项中) → 从数据库生成 → 选择你要映射的数据库的数据源(将 『是,在连接字符串中包含敏感数据』勾上) → 选中要映射的表、视图、存储过程。

下面是使用!

//保证一次请求共用一个上下文实例

var dbContext = DbContextHelper.getCurrentDbContext();
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.Remoting.Messaging;
using System.Web; namespace myWeb
{
public class DbContextHelper
{ //保证一次请求共用一个上下文实例
public static MyDbContext getCurrentDbContext()
{
#region HttpContext方式:内部封装了CallContext,所以HttpContext方式和CallContext方式差别不大
// //HttpCntext:一次请求,HttpContext已经保证只有一个实例
// MyDbContext dbContext = HttpContext.Current.Items["MyDbContext"] as MyDbContext;
// if (dbContext == null)
// { //当前Http上下文不存在当前对象
// dbContext = new MyDbContext();
// HttpContext.Current.Items.Add("MyDbContext", dbContext);
// }
#endregion #region CallContext方式
MyDbContext dbContext = CallContext.GetData("DbContext") as MyDbContext;
if (dbContext == null)
{
dbContext = new MyDbContext();
CallContext.SetData("DbContext", dbContext);
} #endregion return dbContext;
} }
/// <summary>
/// 这里的MyDbCotext类只是打一个比方,实际在用的时候需要更改成项目所需要用的实体类
/// </summary>
public class MyDbContext
{ }
}

DbContextHelper.cs

//1、声明一个EF的上下文
MyTestEntities1 dbcontext = new MyTestEntities1();
//dbcontext.Database.Connection.ConnectionString = "";//重新设置数据库连接字符串(对于非常重要数据库,如银行的账号密码等,需要对数据库字符串进行密钥加密的,可以在这里解密后重新赋值)
 //2、声明一个User实体
//USERS user = new USERS();
//user.NAME = "vichin";
//user.SEX = "男";
//user.DATE = "19921126";
//user.ID = 4;
//user.NUMBER = 4; //3、告诉EF,咱们对实体的做一个插入操作
//dbcontext.USERS.Add(user); //3、告诉EF,咱们对实体的做一个删除操作
//dbcontext.USERS.Remove(user);

做一个 添加/删除 操作

            //2、声明一个实体
USERS user = new USERS();
user.SEX = "男";
user.NAME = "vichin";
user.DATE = "";
user.ID = ; //3、告诉上下文咱们要对此实体进行更新操作 #region 对一整行数据进行更行
dbcontext.Entry<USERS>(user).State = System.Data.Entity.EntityState.Modified;//要做删除的话,只需要将modified改写成Deleted #endregion #region 对一行数据中,某个字段进行更新
dbcontext.USERS.Attach(user);//将新的user对象附加到上下文中来,进行管理
dbcontext.Entry<USERS>(user).Property<string>(u => u.NAME).IsModified = true; // EF5.0之后的写法(VS2012开始使用)
dbcontext.Entry<USERS>(user).Property("NAME").IsModified = true;//EF4.0的写法(VS2010中的写法)
#endregion

做一个更改操作

//4、告诉上下文把实体的变化保存到数据库(执行SQL脚本)
dbcontext.SaveChanges();
       //使用查询语法
var temp = from u in dbcontext.USERS
where u.ID ==
select u;
  
        //查询部分列
        var data = from u in dbcontext.USERS
        select new { u.ID, u.NAME, u.SEX, u.NUMBER };         //使用方法语法
        var temp2 = dbcontext.USERS.Where(u => u.ID == );                //查询部分列
        var data1 = dbcontext.USERS.Where(u => u.ID == ).Select(u=>u.ID);
        var data2 = dbcontext.USERS.Where(u => u.ID == ).Select(u => new { u.ID,u.NAME,u.NUMBER});      //IQueryable<USERS> temp1 = from u in dbcontext.USERS
// where u.ID == 4
// select u;      //上面是在数据库中做了筛选之后才放到内存中的      //linq to object 将数据库的数据全都放到内存中
     //var temp1 = from u in dbcontext.USERS.ToList()
            //where u.ID == 4 
            //select u; #region 分页 var pageData = dbcontext.USERS.Where(u => u.ID > ).OrderBy<USERS, int>(u => u.ID);
//int <==> ID 根据ID来排序,所以在OrderBy后面的泛型约束中TKey 使用int(因为ID是int类型的)
var pageData1 = dbcontext.USERS.Where(u => u.ID > ).OrderBy<USERS, string>(u => u.NAME); //在实际使用中,可以将orderBy后面的泛型约束给省略掉:
var pageData2 = dbcontext.USERS
.Where(u => u.ID > .)
.OrderBy(u => u.NAME)
// 每页5条,要取第三页的数据。从第10条数据开始取5条数据
.Skip(*(-))//越过多少条数据呢? 越过前2页的数据
.Take();//取5条 //使用查询语法做分页
var pageData3 = (from u in dbcontext.USERS
where u.ID >
orderby u.ID descending
select u).Skip().Take();
//还是要用到skip take #endregion

做一个查询

 在对数据库进行删除、更新操作时,一定要将所有的非空字段(实体的属性)赋值,即使在更新的时候用不到那个字段,也得赋值。


方法二:

1、在VS中创建数据库

  点击 view(视图)→sql server对象资源管理器(或者叫数据库资源管理器database Explorer)→在SQL 对象资源管理器中右击Sql Server→添加Sql server.之后再创建的Sql server对象中添加database 和 表(此处以Products为例),并在表中添加一些测试数据。

2、创建数据模型

  数据模型类名为Product

3、添加EF 并创建EF上下文

  install-package entity framework -version5.0

  namespace SportsStore.Models.Repository{

    public class EFDbContext:DbContext{

      public DbSet<Product> Products{get;set;}// Products与表名Products相同,表中每一行数据都用Product来表示

    }  

  }

  在web.config文件中ConfigSections节点后添加数据库连接字符串

  <connectionStrings>
<add connectionString="Data Source=RY4H4GAGMN6Y5LN;Initial Catalog=SportsStore;Integrated Security=True" name="EFDbContext" providerName="System.Data.SqlClient"/>
</connectionStrings>

添加的节点

4、在仓储层中创建一个存储库类,它将对前面创建的EFDbContext类执行操作,并作为应用程序业务逻辑与数据库之间的“桥梁”。

  namespace SportsStore.Models.Repository{

    public class Repository{

      EFDbContext context=new EFDbContext ();

      public IEnumber<Product> Products{get{return context.Products;}}

    }

  }

5、使用(只要创建仓储层对象就可以使用了)

  Repository repo=new Repository();

  repo.Products


当数据库内的表或者字段发生变化时,就会报以下错误:

The model backing the 'EFDbContext' context has changed since the database was created. Consider ....

最直接的方式是删除VS中的数据库,并且重新添加。

linqpad官网: http://www.linqpad.net/  

下面是常见错误(部分)


报错: Unable to update the EntitySet 'USERS' because it has a DefiningQuery and no <InsertFunction> element exists in the <ModificationFunctionMapping> element to support the current operation.

报错:从 ObjectStateEntry 中检索值时出错。有关详细信息,请参阅内部异常。

原因:报这个错的原因是表中没有主键!

————————————————————————————————————————————
代码:dbcontext.Entry<USERS>(user).State = System.Data.EntityState.Modified;

报错:无法将类型"System.Data.EntityState"隐式转换为"System.Data.Entity.EntityState"

原因:这行代码是EF5.0中的写法,如果用的是6.0则需要写成
dbcontext.Entry<USERS>(user).State = System.Data.Entity.EntityState.Modified;

————————————————————————————————————————————
报错:对一个或多个实体的验证失败。有关详细信息,请参阅“EntityValidationErrors”属性。

原因:实体的非空属性没有全部都被赋值,或者是数据的长度超过了定义的类型 (NVARCHAR 100)

————————————————————————————————————————————
报错:存储区更新、插入或删除语句影响到了意外的行数(0)。实体在加载后可能被修改或删除。刷新 ObjectStateManager项

原因:要操作的数据在数据库并不存在。(例如:要删除一个ID为9999的数据,可是当前数据库中并没有ID为9999的数据)

—————————————————————————————————————————————————————————————————————————EF优缺点

  优点:

  1、极大提高开发效率,与VS的开发工具集成度高,开发中没,代码几乎都是强类型的,写代码效率高,自动化程度高,命令式编程。

  2、EF提供的模型设计器非常强大,不仅仅带来了设计数据库的革命,也带来了自动化生成模型代码的功能,极大提高了开发与架构设计的效率。

  3、仅仅通过改变配置,就可以做到夸数据库的能力。

缺点:

  性能差(在生成SQL脚本阶段),在复杂查询的时候,生成的SQL脚本效率不高。

   1、根据XML映射关系及实体的状态生成相应的脚本(相对于SQL语句在数据库中执行的速度来说是慢的,所以在做互联网项目的时候不推荐使用EF,而在做企业级开发的时候,可以使用。)

  2、不在数据端额外的消耗性能

如何使用EF?的更多相关文章

  1. %E3%80%90%E7%BD%91%E7%BB%9C%E7%BC%96%E7%A8%8B%E3%80%91

    "%3Cdiv%20class%3D%22htmledit_views%22%20id%3D%22content_views%22%3E%0A%20%20%20%20%20%20%20%20 ...

  2. 你必须知道的EF知识和经验

    注意:以下内容如果没有特别申明,默认使用的EF6.0版本,code first模式. 推荐MiniProfiler插件 工欲善其事,必先利其器. 我们使用EF和在很大程度提高了开发速度,不过随之带来的 ...

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

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

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

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

  5. EntityFramework之DetectChanges's Secrets(三)(我为EF正名)

    前言 对于应用程序开发者来说,通常不需要考虑太多对于Entity Framework中的变更追踪(change tracking),但是变更追踪和DetectChanges方法是栈的一部分,在这其中, ...

  6. ASP.NET从零开始学习EF的增删改查

           ASP.NET从零开始学习EF的增删改查           最近辞职了,但是离真正的离职还有一段时间,趁着这段空档期,总想着写些东西,想来想去,也不是很明确到底想写个啥,但是闲着也是够 ...

  7. 使用EF CodeFirst 创建数据库

    EntityFramework 在VS2015添加新建项时,选择数据->ADO.NET 实体数据模型,有一下选项 来自数据库的EF设计器,这个就是我们最常用的EntityFramework设计模 ...

  8. EF上下文对象线程内唯一性与优化

    在一次请求中,即一个线程内,若是用到EF数据上下文对象,就创建一个,这也加是很多人的代码中习惯在使用上下文对象时,习惯将对象建立在using中,也是为了尽早释放上下文对象, 但是如果有一个业务逻辑调用 ...

  9. EF里Guid类型数据的自增长、时间戳和复杂类型的用法

    通过前两章Lodging和Destination类的演示,大家肯定基本了解Code First是怎么玩的了,本章继续演示一些很实用的东西.文章的开头提示下:提供的demo为了后面演示效果,前面代码有些 ...

  10. 模仿EF,我们用JS开发的HTML5 SQLite 访问库

    今天终于有空把demo放到了RunJS上面去.请使用google chrome观看在线演示: http://sandbox.runjs.cn/show/pekbd9zb 这个库本来是我们开发的phon ...

随机推荐

  1. 分布式的几件小事(四)dubbo负载均衡策略和集群容错策略

    1.dubbo负载均衡策略 ①random loadbalance 策略 默认情况下,dubbo是random loadbalance 随机调用实现负载均衡,可以对provider不同实例设置不同的权 ...

  2. CentOS下安装DockerCE

    title: CentOS下安装DockerCE comments: false date: 2019-09-04 09:47:58 description: 在CentOS下安装社区版Docker ...

  3. 05 Django之模型层---单表操作

    一 ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人 ...

  4. 使用pt-table-checksum检查主从一致性

    使用 percona 工具检查主从不一致 可以使用 pt-table-checksum  工具检查主从数据的一致性,检查完之后默认会生成一个 percona 库以及一个 checksums 表,记录了 ...

  5. 韦东山嵌入式Linux学习笔记08--中断体系结构

    中断是什么? 举个栗子, 系统怎么知道你什么时候插入鼠标这个设备? 可以有两种处理方式: 1. 查询方式: 轮询去检测是否有设备插入; 2. 中断的方式 当鼠标插入这个事件发生时, 置位某个寄存器,告 ...

  6. linux上搭建单机版hadoop和spark

    依赖的安装包 首先hadoop和spark肯定是必须的,而hadoop是用java编写的,spark是由Scala编写的,所以还需要安装jdk和scala. 大数据第三方组件我们统统都安装在/opt目 ...

  7. Mysql补充部分:SQL逻辑查询语句执行顺序

    一 SELECT语句关键字的定义顺序 SELECT DISTINCT <select_list> FROM <left_table> <join_type> JOI ...

  8. maven 学习之路一

    一.mave介绍: maven :我的理解就是一个代码构建管理的一个工具.类似的工具有gradle,ant等. 官方理解:Apache Maven is a software project mana ...

  9. nvidia-docker安装

    如果之前安装过docker1.0版本,需要先删掉该版本和之前创建的容器 docker volume ls -q -f driver=nvidia-docker | xargs -r -I{} -n1 ...

  10. 双向BFS统计

    Hdu1195 两个四位密码 问你最少多少步能到达 /*Huyyt*/ #include<bits/stdc++.h> #define mem(a,b) memset(a,b,sizeof ...