EF6中执行Sql语句

Posted GIS的天空

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了EF6中执行Sql语句相关的知识,希望对你有一定的参考价值。

EF中提供了两个方法,一个是执行查询的Sql语句SqlQuery,另外一个是执行非查询的语句ExecuteSqlCommand。SqlQuery有两种形式的,一种是泛型的,一种是非泛型的。比如我们要在目录表中查询ID为多少的一个分类。可以这样写:

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

       它会为你自动转换成对应的实体的。另外,如果你想查询目录表中所有的记录数,那么你可以这样写:

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

        如果你想执行一些非查询的Sql语句,你可以调用ExecuteSqlCommand方法,它会返回受影响的行数。你可以这样写:

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

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

int num = dbContext.Database.ExecuteSqlCommand("Select count(*) from catalog");//结果是-1

转自:https://www.cnblogs.com/xiaoxiangfeizi/p/3551855.html,表示感谢。

以上是关于EF6中执行Sql语句的主要内容,如果未能解决你的问题,请参考以下文章

在 EF6 中执行复杂的原始 SQL 查询

EF Core 执行sql语句

EF6 自定义迁移表名

EF6.0 下sql语句自动生成的参数类型decimal(18,2)修改

DbCommandInterceptor抓取EF执行时的SQL语句

DbCommandInterceptor抓取EF执行时的SQL语句