自从我开始使用Visual Studio 也已经经历了好几个版本了,而且这中间EF等框架的改变也算是比较多的。本篇文章记录下各个版本EF执行Sql语句和直接进行增删查改操作的区别,方便自己随时切换版本。目前我们公司同时在使用VS2010 对应EF4和VS2015 对应EF5和EF6,因为有些老的项目必须得定期更新维护。

一、新增

UserList u = new UserList();

           u.name=name;

           u.age = age;

           u.jointime = date;

//添加,这个只是在内存上操作

            db.UserList.AddObject(u);

            //保存到数据库

            db.SaveChanges();

而在EF5中使用Add

db.UserList.Add(u );

二、删除

          //需要一个实体对象参数
//1,创建要删除的对象
//UserList modelDel = new UserList() { ID = id };
UserList list = db.UserList.FirstOrDefault(c => c.ID == id);
//2,将对象添加到EF管理容器中(没有这步也可以删除)
//db.UserList.Attach(list);
//3,修改对象的包装类对象标识为删除状态
db.UserList.DeleteObject(list);
//4,更新到数据库
db.SaveChanges();

而在ef5中使用Remove

EF.TourList.Remove(model);

三、修改   update

  EF中会为每个管理的实体对象创建一个代理包装类对象,其中会跟踪 实体对象 的状态和每个属性的状态;

  3.1 先查询再修改

  通常使用EF更新的方式,先查询出要修改的数据,然后再修改新的值;实体对象被修改的属性 在 代理包装类对象里 的对应属性状态会被修改记录下修改状态,等到调用SaveChanges时,EF会遍历其管理的每个实体对象,并根据其 包装类对象 的状态,生成增删改查sql语句并执行;

此例中修改操作,会生成 修改的sql语句(注意:此处只为修改过的属性生成sql语句),最后执行。

缺点:修改先还要查询,难受

//1.先查询要修改的原数据

Models.BlogArticle modelNew = db.BlogArticles.Where(a => a.AId == model.AId).FirstOrDefault();

//2.设置修改后的值

modelNew.ATitle = "新的数据";

modelNew.AContent = "新的数据~~~~~~";

modelNew.ACate = ;

//3.跟新到数据库

db.SaveChanges();

  3.2直接修改

  为避免先查询数据库,可以直接将 被修改的实体对象 添加到 EF中管理(此时为附加状态Attached),并手动设置其为未修改状态(Unchanged),同时设置被修改的实体对象的包装类对象 对应属性为修改状态。

优点:修改前不需要查询数据库。

EF4中,使用方法

lover.state = ;

                        lover.id = ;

                        //0.1添加到EF管理容器中,并获取 实体对象 的伪包装类对象

                        EF.CreateObjectSet<Love>().Attach(lover);

                        EF.ObjectStateManager.ChangeObjectState(lover, EntityState.Modified);

                        EF.SaveChanges();

                        res = "existAndUpdate";

这种方法,如果之前查询了这个id的实例对象,那么要释放,使用自己写dispose方法。

EF5中的使用方法

//0.0创建修改的 实体对象

Models.BlogArticle model = new BlogArticle();

model.AId = ;

model.ATitle = "新的数据";

model.AContent = "新的数据~~~~~";

//0.1添加到EF管理容器中,并获取 实体对象 的伪包装类对象

DbEntityEntry<Models.BlogArticle> entry = db.Entry<Models.BlogArticle>(model);

//**如果使用 Entry 附加 实体对象到数据容器中,则需要手动 设置 实体包装类的对象 的 状态为 Unchanged**

//**如果使用 Attach 就不需要这句

entry.State = System.Data.EntityState.Unchanged;

//0.2标识 实体对象 某些属性 已经被修改了

entry.Property("ATitle").IsModified = true;

entry.Property("AContent").IsModified = true;

//3.跟新到数据库

db.SaveChanges();

四、执行Sql命令

EF4中使用案例

//案例1

 var peopleViews = db.ExecuteStoreQuery<PersonView>("SELECT PersonID, Name FROM Person");

//案例2

string findTableSql = "SELECT TABLE_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE COLUMN_NAME = '"

                                + templetName+"'";

                            //比较怕这个字段在很多表里面都有

                            loopTable = db.ExecuteStoreQuery<string>(findTableSql).FirstOrDefault();

                            string totalCountSql = "select count(0) from " + loopTable;

                            loopNumber = db.ExecuteStoreQuery<int>(totalCountSql).FirstOrDefault();

根据返回值的类型,设置接收容器类型,也可以直接使用VAR

EF5使用案例

string sqlString = "select * from VoteDetail where PhoneNumber='" + phoneNumber + "' and VotePicId="

                        + id + " and [VoteDate]='" + nowDate + "'";

                    //比较怕这个字段在很多表里面都有

                    VoteDetail findTable = db.Database.SqlQuery<VoteDetail>(sqlString).FirstOrDefault();

这是比较常用的方法,实际上,是有两种执行方式的。

EF model first方式, 你的DB是继承ObjectContext

using (MyObjectContext db = new MyObjectContext() )

{

    string sql = “ select columnA, columnB from TableA where  =  ”;

    db.ExecuteStoreQuery<TableAObject>(sql).ToList();//TableAObject就是你定义的对象,对象属性就是columnA, columnB

}

code  first, 你的db是继承DbContext

using (MyDbContext db = new MyDbContext() )

{

    string sql = “ select columnA, columnB from TableA where  =  ”;

    db.TableAObject.SqlQuery(sql).ToList();//TableAObject就是在MyDbContext 定义的对象

 }

这里只是列举查询的方式,仅供参考,一般新增 删除 或者修改 用对象的方式比较多,如果是sql,一般是

db.Database.ExecuteSqlCommand(sqlString)

这里面说下区别:

ExecuteSqlCommand与SqlQuery

  在数据上下文DBModel的实例中有个Database属性,其中有两组方法.ExecuteSqlCommand()和.SqlQuery()。它们都可以执行SQL语句,只不过.ExecuteSqlCommand()是不返回结果的,只返回受影响的行数,所以.ExecuteSqlCommand()更适合执行创建、更新、删除操作。.SqlQuery()则会返回查询到的结果,并将结果保存在数据实体中,所以更适合执行查询操作

五、延伸阅读

http://www.16aspx.com/Article/3525

分享基于Entity Framework的Repository模式设计源码

http://www.cnblogs.com/JustRun1983/p/3261074.html

Entity Framework返回IEnumerable还是IQueryable?

EF各版本增删查改及执行Sql语句的更多相关文章

  1. EF增删查改加执行存储过程和sql语句,多种方法汇总

    ActionUrl c = new ActionUrl() { ActionName="test", RequestUrl="/123/123", SubTim ...

  2. EF简单的增删查改

    Add /// <summary> /// /// </summary> public void Add() { TestDBEntities2 testdb = new Te ...

  3. EF 集合版 增删查改

  4. 009.增删查改语法(sql实例)

    --------------------------------------------合并结果集SELECT UNION -------------------------------------- ...

  5. Asp.Net MVC EF之一:使用Database类在EF框架中执行Sql语句

    引言 从EF6开始,增加了DateBase类,他通过从 DbContext 对象获取此类的实例.可用于管理支持数据库上下文或连接的实际数据库.这包括创建.删除和检查数据库的存在. 在6以前,我们使用E ...

  6. 3.EF 6.0 Code-First实现增删查改

    原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-entity-framework-5-0-code- ...

  7. JDBC终章- 使用 DBUtils实现增删查改- C3P0Utils数据源/QueryRunner runner连接数据源并执行sql

    JDBC终章- 使用 DBUtils实现增删查改 1.数据库结构 Create Table CREATE TABLE `user` ( `id` ) NOT NULL AUTO_INCREMENT, ...

  8. 4.在MVC中使用仓储模式进行增删查改

    原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-using-the-repository-pattern-in-mvc/ 系列目录: ...

  9. 使用EntityFramework6完成增删查改和事务

    使用EntityFramework6完成增删查改和事务 上一节我们已经学习了如何使用EF连接数据库,并简单演示了一下如何使用EF6对数据库进行操作,这一节我来详细讲解一下. 使用EF对数据库进行操作, ...

随机推荐

  1. pyhton3 re模块

    本文转自 AstralWind 的博客:Python正则表达式指南 特来收藏 1. 正则表达式基础 1.1. 简单介绍 正则表达式并不是Python的一部分.正则表达式是用于处理字符串的强大工具,拥有 ...

  2. iOS WKWebView OC 与 JS 交互学习

    我写WKWebView 想让 服务端相应 一个 方法但是不响应,根据 UIWebView 用 JSContext就能拿到响应的处理经验是不是服务端 也需要 对 WKwebView有兼容的一个写法??? ...

  3. webbrowser控件——Windows下的开发利器

    首先说明,本人比较菜,做C++没多长时间. 刚开始用MFC写程序时,连个基本的字体都不会变(颜色.大小等), 索性干脆就啥也不改了,直接默认,界面就那样了,老子不管了. 心想这C++做个界面咋就那么麻 ...

  4. Hibernate一对多、多对一关联

    一对多.多对一关联:在多方加外键 示例:Group(一方)和User(多方),一个Group可以有多个User,每个User只能属于一个Group   多对一单向关联 在User(多方)中建Group ...

  5. Python学习进程(14)异常处理

        本节介绍Python进行异常处理的方式,异常处理机制可以帮助我们调试python程序.     (1)异常的简介:     异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行 ...

  6. 【leetcode刷题笔记】Palindrome Partitioning II

    Given a string s, partition s such that every substring of the partition is a palindrome. Return the ...

  7. php自带函数去除html标记

    strip_tags 去掉 HTML 及 PHP 的标记. 语法: string strip_tags(string str); 传回值: 字串 函式种类: 资料处理 内容说明 本函式可去掉字串中包含 ...

  8. Linux文件系统及文件储存方式【转】

    本文转载自:https://blog.csdn.net/qyp199312/article/details/54927843 前言 Linux文件系统构成 文件式的文件结构 Linux的一个具体文件 ...

  9. Docker 数据管理-bind mount

    Use bind mounts Bind mounts have been around since the early days of Docker. Bind mounts have limite ...

  10. 使用shell统计字符串出现的次数,并从大到小进行排序显示