EF core的原生SQL查询以及用EF core进行分页查询遇到的问题

摘要:
在使用中,Netcore需要处理一些复杂的查询来访问数据库,因此必须使用本机SQL查询。然而,EFCore和EF6具有非常不同的本机SQL查询。EFCore将其视为子查询,并将其合并到数据库中。导致查询错误的解决方案是防止查询操作的组合。在FromSql方法之后,立即使用AsEnumerable或AsAsyncEnumerable方法,以确保EFCore不会尝试组合存储过程。

在用.net core进行数据库访问,需要处理一些比较复杂的查询,就不得不用原生的SQL查询了,然而EF Core 和EF6 的原生sql查询存在很大的差异。

在EF6中我们用SqlQuery和ExecuteSqlCommand进行sql语句的执行,而在EF Core中我们则使用FromSql和ExecuteSqlCommand

一.ExecuteSqlCommand(这两者没什么太大的区别)

        Company08Entities db = new Company08Entities();
        string sql = string.Format("update Cars set IsPub='是',PubTime='{1}' where Id in ({0})",ids,DateTime.Now);
            int res = db.Database.ExecuteSqlCommand(sql);    //返回受影响的行数
            if (res>0)
            {
                return Json(new UIResult(true,"发布成功!"));
            }
            else
            {
                return Json(new UIResult(false,"发布失败,请重试!"));
            }

二.数据库查询语句两者的差别就太大了,这里我会详细举例说明

  1.在EF6中使用SqlQuery进行查询以及联和Linq进行分页

     Company08Entities db = new Company08Entities();
     string sql = "select c.* from Cars c join ResCommend r on c.Id=r.ResId where r.Posld=2 and DeadLine>GETDATE() and c.IsPub='是'";
     var res = db.Database.SqlQuery<Cars>(sql); var list = res.Skip((pn - 1) * pz).Take(pz).ToList(); //其中pn为页码,pz为页大小

  2.在EF Core中我们使用FromSql

    新版本需要安装:Microsoft.EntityFrameworkCore.Relational 这个包,而且还需要引用 Microsoft.EntityFrameworkCore这个命名空间

      private Company08Context db = null;
        public ProductController(Company08Context context)
        {
            this.db = context;
        }
       String sql =string.Format($"select c.* from Cars c join ResCommend r on c.Id=r.ResId where r.Posld=2 and DeadLine>GETDATE() and c.IsPub='是'");
            
                //var res = db.Cars.FromSql(sql);  已过时
                var res = db.Cars.FromSqlRaw(sql);
                var list = res.Skip((pn-1)*pz).Take(pz).ToList();

    这中使用 LINQ 运算符在初始的原始 SQL 查询基础上进行组合会出现以下这种问题

  EF core的原生SQL查询以及用EF core进行分页查询遇到的问题第1张

     这是因为使用 LINQ 运算符在初始的原始 SQL 查询基础上进行组合。 EF Core 将其视为子查询,并在数据库中对其进行组合,导致查询出错

    解决方案就是阻止查询运算操作的组合,FromSql 方法之后立即使用 AsEnumerableAsAsyncEnumerable 方法,确保 EF Core 不会尝试对存储过程进行组合。

       String sql =string.Format($"select c.* from Cars c join ResCommend r on c.Id=r.ResId where r.Posld=2 and DeadLine>GETDATE() and c.IsPub='是'");
          //  var res = db.Cars.FromSql(sql).AsEnumerable();  //新版中 FromSql 已过时
            var list=res.Cars.FromSqlRaw(sql);
        var list = res.Skip((pn-1)*pz).Take(pz).ToList();

  

免责声明:文章转载自《EF core的原生SQL查询以及用EF core进行分页查询遇到的问题》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇DBCC命令汇总layui 时间插件laydate中动态设置改变min和max值下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

分库分表利器——sharding-sphere

背景 得不到的东西让你彻夜难眠,没有尝试过的技术让我跃跃欲试。 本着杀鸡焉用牛刀的准则,我们倡导够用就行,不跟风,不盲从。 所以,结果就是我们一直没有真正使用分库分表。曾经好几次,感觉没有分库分表(起码要分表),项目就做不下去了,但是由于跨部门、工具约束、项目被砍等各种原因最终都偃旗息鼓,乖乖的搞单表加索引去了。 应该是没有及时同步公司内部知识库的原因,过...

手动升级11.2.0.3到12.2.0.1

手动升级11.2.0.3到12.2.0.1参考资料:1.如何下载并运行Oracle数据库预升级实用程序 (文档 ID 1577379.1)2.https://docs.oracle.com/en/database/oracle/oracle-database/12.2/upgrd/example-manual-upgrade-windows-non-cdb...

hive深入使用

Hive表的创建和数据类型 https://cwiki.apache.org/confluence/display/Hive/Home 管理表和外部的区别 # 管理表 1. 内部表也称之为MANAGED_TABLE; 2. 默认存储在/user/hive/warehouse下,也可以通过location指定; 3. 删除表时,会删除表数据以及元数据; #...

Base64加密解密

Base64加密解密using System; using System.Collections.Generic; using System.Text; namespace Dachie { class Program { static void Main(string[] args) {...

Access sql语句创建表及字段类型

创建一张空表: Sql="Create TABLE [表名]" 创建一张有字段的表: Sql="Create TABLE [表名]([字段名1] MEMO NOT NULL, [字段名2] MEMO, [字段名3] COUNTER NOT NULL, [字段名4] DATETIME, [字段名5] TEXT(200), [字段名6] TEXT(200))...

Oracle加密解密

Oracle内部有专门的加密包,可以很方便的对内部数据进行加密(encrypt)和解密(decrypt).   介绍加密包之前,先简单说一下Oracle基本数据类型——RAW类型。   RAW,用于保存位串的数据类型,类似于CHAR,声明方式RAW(L),L为长度,以字节为单位,作为数据库列最大2000,作为变量最大32767字节。      操作RAW类...