首页 > 编程语言 > 详细

could not be translated. Either rewrite the query in a form that can be translated, or switch to client evaluation explicitly by inserting a call to 'AsEnumerable',

时间:2021-08-22 09:17:52      阅读:42      评论:0      收藏:0      [点我收藏+]
The LINQ expression ‘DbSet<Supplies>()
          .Where(s => s.alarmState == "缺货")
          .Where(s => !(__invalidList_0
              .Any(y => s.id == y.id)))‘ could not be translated. Either rewrite the query in a form that can be translated, or switch to client evaluation explicitly by inserting a call to ‘AsEnumerable‘, ‘AsAsyncEnumerable‘, ‘ToList‘, or ‘ToListAsync‘. See https://go.microsoft.com/fwlink/?linkid=2101038 for more information.

执行下面语句出错,我得到的错误是"无法翻译.要么以可以翻译的形式重写查询,要么通过插入对AsEnumerable(),AsAsyncEnumerable(),ToList()或ToListAsync()."

 db.ApplicationForm.Where(x => realNeedApplyList.Any(y => x.id == y.applicationformid));

 

也就是 在where 中认不出 y.applicationformid,所以改一下

var applicationformids = realNeedApplyList.Select(x => x.applicationformid);
var applicationform = db.ApplicationForm.Where(x => applicationformids.Contains(x.id));

改成两句就可以了。

 

could not be translated. Either rewrite the query in a form that can be translated, or switch to client evaluation explicitly by inserting a call to 'AsEnumerable',

原文:https://www.cnblogs.com/lunawzh/p/15170799.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!