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


    在用.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 查询基础上进行组合会出现以下这种问题

      

         这是因为使用 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();

      

  • 相关阅读:
    Serverless 动态博客开发趟“坑”记
    tsv与csv文件
    zypper
    source、sh、./三种执行方式对脚本变量的影响
    linux nm
    ldconfig
    cpio
    License简介
    rpm之spec文件
    使用rpmbuild制作rpm包
  • 原文地址:https://www.cnblogs.com/HTLucky/p/11686016.html
Copyright © 2020-2023  润新知