首页 咨询中心 IT学堂
LING TO SQL Entity FrameworkEF中直接运行SQL命令
使用EFLING TO SQL Entity FrameworkEF中用db.Database.ExecuteSqlCommand() 和db.ExecuteStoreQuery方法直接运行SQL命令方法,
现在有了EF4.1,API的名字又有了些许改变。如果说DbContext将ObjectContext做了包装,那么DbContext.Database就是对应于数据库端信息的封装。执行SQL命令也自然从  
Database类型开始。对应于ExecuteStoreCommand和ExecuteStoreQuery的是  
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; }  
}  


 在 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 { get; set; } 
    public string Name { get; set; } 
上一篇 sql 中的糊查询like 语句等于 LINQ TO SQL中的.Contains()
上一篇 .netmvc网站建设razor代码块混合js嵌套JS代码方法
本方链接: http://www.web258.cn/article/show/i1357.html
ARTICLE 相关推荐