微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 使用if语句的LINQ WHERE子句

我正在使用c#.net

我有两个文本框,if!empty需要成为LINQ查询中WHERE子句的一部分.

这是我的代码

var result = from a in xxxx select a;

if(!string.IsNullOrEmpty(personName))
{
    return result.Where(a >= a.forename.Contains(personName) || a.surname.Contains(personName)     
}
else if(!string.IsNullOrEmpty(dateFrom))
{
    return result.Where(a >= a.appStartDateTime >= dateFrom.Date)
}
else if(!string.IsNullOrEmpty(personName) && !string.IsNullOrEmpty(dateFrom))
{
    return result.Where(a >= a.forename.Contains(personName) || a.surname.Contains(personName) &&   a.appStartDateTime >= dateFrom.Date);
}

我认为这会起作用,但它不喜欢.Where和我无法访问’a’,例如a.forename(名称’a’在当前上下文中不存在)

我出了什么问题,或者实际上不能做到这一点?

在此先感谢您的帮助.

克莱尔

解决方法

而不是这个:
result.Where(a.forename.Contains(personName))

试试这个:

result.Where(a => a.forename.Contains(personName))

您似乎缺少Lambda运算符(=>).

原文地址:https://www.jb51.cc/csharp/100138.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐