C# 在EF中直接运行SQL命令
2017-03-13 10:58
323 查看
相信不少使用EF的同志们已经知道如何在EF中运行SQL命令了。我在这里简单总结下,希望对大家学习EF有所帮助! 在 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)中,我们有了全新的API:ObjectContext.ExecuteStoreCommand(...)和 ObjectContext.ExecuteStoreQuery<T>(...)。从函数名不难知道前者是为了执行某一并无返回集的SQL 命令,例如UPDATE,DELETE操作;后者是执行某一个查询,并可以将返回集转换为某一对象。 using (var ctx = new MyObjectContext()) { ctx.ExecuteStoreCommand("UPDATE Person SET Name = 'Michael' WHERE PersonID = 1"); } 复制代码 using (var ctx = new MyObjectContext()) { var peopleViews = ctx.ExecuteStoreQuery<PersonView>("SELECT PersonID, Name FROM Person"); } public class PersonView { public int PersonID { get; set; } public string Name { get; set; } } 复制代码 现在有了EF4.1,API的名字又有了些许改变。如果说DbContext将ObjectContext做了包装,那么DbContext.Database就是对应于数据库端信息的封装。执行SQL命令也自然从Database类型开始。对应于ExecuteStoreCommand和ExecuteStoreQuery<T>的是Database.ExecuteSqlCommand和Database.SqlQuery<T>。 using (var ctx = new MyDbContext()) { ctx.Database.ExecuteSqlCommand("UPDATE Person SET Name = 'Michael' WHERE PersonID = 1"); } 复制代码 using (var ctx = new MyDbContext()) { var 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
相关文章推荐
- 在EF中直接运行SQL命令
- Entity Framework 小技巧二 —— 如何在EF中直接运行SQL命令
- 实用笔记-EF中直接运行SQL命令
- Entity Framework(EF) 直接执行数据库命令并返回 DataTable 数据参数化 SQL 语句
- entity framework(EF) 直接执行数据库命令并返回DataTable 参数化sql语句
- DA中直接运行SQL命令,并返回影响行数
- DA中直接运行SQL命令,并返回影响行数
- 直接通过mysql命令运行sql脚本
- SQL Server中存储过程比直接运行SQL语句慢的原因(转载)
- 在C#中建立复杂的、灵活的SQL查询/命令
- SQL Server中存储过程比直接运行SQL语句慢的原因
- SQL Server中存储过程比直接运行SQL语句慢的原因
- SQL Server中存储过程比直接运行SQL语句慢的原因
- 遭遇C# 运行数据库命令时connetion Timeout expired异常问题
- c#运行shell命令
- 使用C#代码安装 Windows 服务--直接运行安装服务
- LINQ TO SQL:直接执行查询和命令
- 一个查选优化的例子,转--SQL Server中存储过程比直接运行SQL语句慢的原因
- 一个查选优化的例子,转--SQL Server中存储过程比直接运行SQL语句慢的原因
- 在C#中建立复杂的、灵活的SQL查询/命令