文章内容

2017/5/31 16:56:33,作 者: 黄兵

Entity Framework 小技巧二 —— 如何在EF中直接运行SQL命令


相信不少使用EF的同志们已经知道如何在EF中运行SQL命令了。我在这里简单总结下,希望对大家学习EF有所帮助!

在EF第一个版本(.NET 3.5 SP1)中,我们只能通过将ObjectContext.Connection转换为EntityConnection,再把EntityConnection.StoreConnection转换为SqlConnection。有了这个SqlConnection,我们再创建SqlCommand便能顺利运行SQL命令了。(个人觉得其实很烦,呵呵)

在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 { getset; }
    
public string Name { getset; }
}

现在有了EF4.1,API的名字又有了些许改变。如果说DbContext将ObjectContext做了包装,那么DbContext.Database就是对应于数据库端信息的封装。执行SQL命令也自然从Database类型开始。对应于ExecuteStoreCommand和ExecuteStoreQuery<T>的是Database.ExecuteSqlCommandDatabase.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 { getset; }
    
public string Name { getset; }
}

本文转载自:http://www.cnblogs.com/lingzhisun/archive/2011/04/15/ef_trick2.html

分享到:

发表评论

评论列表