ef mysql 分页查询语句_EF core的原生SQL查询以及用EF core进行分页查询遇到的问题...

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

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

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

Company08Entities db = newCompany08Entities();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 = newCompany08Entities();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(sql);var list = res.Skip((pn - 1) * pz).Take(pz).ToList(); //其中pn为页码,pz为页大小

2.在EF Core中我们使用FromSql

private Company08Context db = null;publicProductController(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 list = res.Skip((pn-1)*pz).Take(pz).ToList();

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

6615160c9ce68096f825ca8af8963a16.png

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

解决方案就是阻止查询运算操作的组合,在 FromSql 方法之后立即使用 AsEnumerable 或 AsAsyncEnumerable 方法,确保 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();var list = res.Skip((pn-1)*pz).Take(pz).ToList();

原文:https://www.cnblogs.com/HTLucky/p/11686016.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值