asp.net-mvc-3 – 在LINQ Query中调用一个方法
发布时间:2020-12-16 07:12:15 所属栏目:asp.Net 来源:网络整理
导读:我有一个LINQ查询与自定义模型.我只是想使用一种方法为模型属性赋值.但是当我尝试使用自定义模型时,它会抛出一些错误消息,如下所示: LINQ to Entities does not recognize the method ‘System.String GetPONo(Ent,System.String)’ method,and this method
我有一个LINQ查询与自定义模型.我只是想使用一种方法为模型属性赋值.但是当我尝试使用自定义模型时,它会抛出一些错误消息,如下所示:
码 var model = (from p in db.PoDetails select new porders { Category = p.Category,PONO = GetPONo(p,p.Category),}).ToList(); 方法 public string GetPONo(PoDetail p,string ASD) { if (ASD == "B") { var PoNo = (from pord in db.Porders where pord.Id == p.PoId select pord.No).FirstOrDefault(); return PoNo; } else { var PoNo = (from porder in db.Porders where porder.Id == (from rec in db.RecommendResources where rec.Id == p.BibId select rec.PoId).FirstOrDefault() select porder.No).FirstOrDefault(); return PoNo; } } 解决方法
您可以使用三元运算符根据类别值为PONO执行不同的子查询
var model = (from p in db.PoDetails select new porders { Category = p.Category,PONO = p.Category == "B" ? (from pord in db.Porders where pord.Id == p.PoId select pord.No).FirstOrDefault() : (from porder in db.Porders where porder.Id == (from rec in db.RecommendResources where rec.Id == p.BibId select rec.PoId).FirstOrDefault() select porder.No).FirstOrDefault() }).ToList(); 您也可以为此创建存储过程. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 在哪里可以找到好的ASP.NET教程(或书籍)在线?
- asp.net – 在控制台.NET核心应用程序中创建用户
- 24.集成ASP.NETCore Identity
- asp.net – 如何确定以下默认Web配置值?
- asp.net-mvc – 在哪里将日期转换为UTC?
- 在ASP.Net中防止SQL注入
- asp.net-core – 在Visual Studio 2015 for ASP.NET Core项
- asp.net-mvc – ASP.NET MVC – 如何获取一个动作的完整路径
- 使用.net数据注释验证颜色(十六进制值)
- asp.net-core-mvc – MVC6路由到单页面应用程序而不会丢失4
推荐文章
站长推荐
- asp.net – 和debug =“false”有什么区别?
- asp-classic – If子句未按预期工作
- ASP.NET MVC注定要取代Webforms吗?
- asp.net-mvc-3 – 在MVC 3的AuthorizeAttribute中
- asp.net-mvc-3 – 如何在MVC3中为iframe的src属性
- asp.net-mvc-3 – 最初未显示Telerik MVC Grid C
- asp.net – 禁用javascript中的复选框,并在服务器
- asp.net – 请帮我理解web.config自定义设置的ty
- asp.net-mvc – 剃刀替换的优点(@href)
- ASP.NET Core知多少(7):对重复编译说NO -- do
热点阅读