在EF中直接运行SQL命令

一、在 EF第一个版本(.NET 3.5 SP1)中

通过将ObjectContext.Connection转换为EntityConnection,

再把 EntityConnection.StoreConnection转换为SqlConnection。

有了这个SqlConnection,我们再创建 SqlCommand便能顺利运行SQL命令了。

例如:

EntityConnection entityConnection = (EntityConnection)ctx.Connection;
      DbConnection storeConnection = entityConnection.StoreConnection;
      DbCommand cmd = storeConnection.CreateCommand();
      cmd.CommandType = System.Data.CommandType.StoredProcedure;
      cmd.CommandText = "[PRO_USER_DIGITALCARD_CHECK]";

....

二、在EF4(.NET 4)中

ObjectContext.ExecuteStoreCommand(...)     执行某一并无返回集的SQL 命令,例如ADD,UPDATE,DELETE操作

ObjectContext.ExecuteStoreQuery<T>(...)     执行某一个查询,并可以将返回集转换为某一对象

using (var ctx = new MyObjectContext())
{
    int result = ctx.ExecuteStoreCommand("UPDATE Person SET Name = ‘Michael‘ WHERE PersonID = 1");
}
using (var ctx = new MyObjectContext())
{
    IEnumerable<PersonView> peopleViews = ctx.ExecuteStoreQuery<PersonView>("SELECT PersonID, Name FROM Person");
}

public class PersonView
{
    public int PersonID { get; set; }
    public string Name { get; set; }
}

三、在EF4.1中

DbContext将ObjectContext做了包装,

DbContext.Database就是对应于数据库端信息的封装

执行SQL命令也从Database类型开始

using (var ctx = new MyDbContext())
{
    int result = ctx.Database.ExecuteSqlCommand("UPDATE Person SET Name = ‘Michael‘ WHERE PersonID = 1");
}
using (var ctx = new MyDbContext())
{
    IEnumerable<PersonView> peopleViews = ctx.SqlQuery<PersonView>("SELECT PersonID, Name FROM Person").ToList();
}

public class PersonView
{
    public int PersonID { get; set; }
    public string Name { get; set; }
}

原文地址:

http://www.cnblogs.com/chengxiaohui/articles/2092001.html

时间: 2024-08-28 10:01:18

在EF中直接运行SQL命令的相关文章

C# 在EF中直接运行SQL命令

相信不少使用EF的同志们已经知道如何在EF中运行SQL命令了.我在这里简单总结下,希望对大家学习EF有所帮助! 在 EF第一个版本(.NET 3.5 SP1)中,我们只能通过将ObjectContext.Connection转换为EntityConnection,再把 EntityConnection.StoreConnection转换为SqlConnection.有了这个SqlConnection,我们再创建 SqlCommand便能顺利运行SQL命令了.(个人觉得其实很烦,呵呵) 例如: E

实用笔记-EF中直接运行SQL命令

在EF4.1,API的名字 有了些许改变,DbContext.Database就是对应于数据库端信息的封装.执行SQL命令也自然从Database类型开始.对应于ExecuteStoreCommand和ExecuteStoreQuery<T>的是Database.ExecuteSqlCommand和Database.SqlQuery<T>. 1.执行command String using (var ctx = new MyDbContext()) { ctx.Database.E

EF中执行原生sql与使用Local获取本地数据

使用DbSet的Local属性可以访问当前context中被追踪且没有被标记为删除的实体(内存中的数据) 1 using (var context = new BloggingContext()) 2 { 3 // Load all blogs from the database into the context 4 context.Blogs.Load(); 5 6 // Add a new blog to the context 7 context.Blogs.Add(new Blog {

EF中自编写SQL脚本查询结果(适用于复杂SQL逻辑提高查询效率)

前不久项目开发过程中,使用的是Entity Framework做数据处理.因为本人也不是对EF太有研究,只是会用而已,但是在一次需要查询的结果需要关联3.4个表来查询出来结果,并且对查询效率也有要求.但是个人觉得遇到这样的情况还是使用原始SQL语句来查询更为可控(或许EF中有更好的方法可以解决此类问题,但恕本人愚笨只想到了这种方法).就又自己扩展出一个方法,用来专门查询自定义编写的SQL语句.代码如下: public List<T> ExecuteStoreQuery(string comma

SQL service 中的 ”输入SQL命令窗口“ 打开了 “属性界面” 回到 ”输入SQL命令窗口“

输入SQL命令窗口点击上面的菜单栏中的 "窗口" 原文地址:https://www.cnblogs.com/lidar/p/8873890.html

在EF中直接执行SQL语句

最近考虑到并发的问题,用 EF 处理并发非常麻烦, 直接用原生SQL简单: Database.ExecuteSqlCommand:不用返回结果,比如Update等等, Database.SqlQuery<T>:返回结果,比如查询 例: db.Database.ExecuteSqlCommand("update tbMemberAccount set Sum_Recharge=Sum_Recharge+{0},Left_ECurrency=Left_ECurrency+{0},Upda

dedecms:织梦文章如何添加“自定义属性”标签(sql命令行工具)

dede织梦如何添加“自定义属性”标签“症状” 1.进入后台——系统——SQL命令行工具——运行SQL命令行,添加arcatt表字段: insert into`dede_arcatt`(sortid,att,attname) values(9,'d','症状') 2.添加archives表字段: alter table `dede_archives` modify `flag` set ('h','c','p','f','s','j','a','b','d') default NULL     

转发:使用sql命令查询视图中所有引用的基础表

转自:使用sql命令查询视图中所有引用的基础表 使用sql命令查询视图中所有引用的基础表 之前有写过如何利用sql查询视图中所有引用的表发现这个方法并不能查出视图中所有的基础表,如果视图中有嵌套视图就会有问题,因为目录视图sys.sql_dependencies并不包含所有的引用实体.后面发现在sql2008及以后的版本中推出的sys.sql_expression_dependencies视图解决了这一问题,所以重新写了段sql,用来查询视图中所有引用的基础表,包括嵌套视图中的基础表.这个有什么

如何在linux中运行sql文件

1.在linux中进入sql命令行 mysql -u root -p   输入密码 2.假设home下面有a.sql文件 先得use databasename,要不会报错 “No Database Selected” 然后source /home/a.sql 记得home前面要有 / 要不会报错 不能打开这个文件的. ---------------------------------------- 还有一个更好的方法: 使用navicat来连接linux下的mysql数据库 然后再navicat