Entity Framework中执行Sql语句

       若是想在EF框架中执行Sql语句,其实很简单,EF里面已经提供了相关的方法(此处使用的EF为EF4.1版本)。app

       EF中提供了两个方法,一个是执行查询的Sql语句SqlQuery,另一个是执行非查询的语句ExecuteSqlCommand。使用起来也很简单。SqlQuery有两种形式的,一种是泛型的,一种是非泛型的。好比咱们要在目录表中查询ID为多少的一个分类。能够这样写:框架

entityList = dbContext.Set<Catalog>().SqlQuery("Select * from catalog where CatalogID='1234'").ToList();

       它会为你自动转换成对应的实体的。另外,若是你想查询目录表中全部的记录数,那么你能够这样写:spa

int countNum = dbContext.Database.SqlQuery<int>("Select count(*) from catalog").ToList()[0];

        若是你想执行一些非查询的Sql语句,你能够调用ExecuteSqlCommand方法,它会返回受影响的行数。你能够这样写:code

int num = dbContext.Database.ExecuteSqlCommand("delete from catalog where CatalogID='212222' ");

        返回值是执行这个非查询语句后,受影响的行数。若是你在ExecuteSqlCommand方法中传入了一个查询类的Sql语句,无论查询出来的结果是什么,它返回的都是-1。如:ip

int num = dbContext.Database.ExecuteSqlCommand("Select count(*) from catalog");//结果是-1
相关文章
相关标签/搜索