首页 / C# / c# – 如何使用LINQ链接OR子句?
c# – 如何使用LINQ链接OR子句?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 如何使用LINQ链接OR子句?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含968字,纯文字阅读大概需要2分钟。
内容图文
我有一个场景,我需要使用LINQ构建一个SQL查询,其中包含可变数量的OR子句.我正在编写一个函数,它将根据一些输入构建查询.函数定义看起来类似于……
function BuildQuery(ICollection<ColumnsThatNeedToBeTrue> columns)
{
...
}
所以,我给了一个我需要检查的列的集合,并且检查需要使用OR子句.
如果列数组包含A和B,我需要查询来检查列A是否为真或列B为真.
如果columns数组包含A,B和C,我需要查询并检查A OR B OR C是否为真.
我不知道如何在一个单一的地方做这一切,因为我不知道如何逐步增加额外的||条款.基于输入数组,我不确定如何在下面包含额外的OR检查.
var query = entities.Where(m => m.A == true || m.B == true ...)
我不能链接Where函数,每个函数用于自己的列检查,因为它使用AND子句构建该查询,我需要OR.
有没有办法使用LINQ构建这样的查询?
解决方法:
您可以使用PredicateBuilder链或条件.
var predicate = PredicateBuilder.False<SomeEntity>();
predicate = predicate.Or (p => p.A == true);
if(something)
predicate = predicate.Or (p => p.B == true);
var query = entities.AsExpandable().Where (predicate); //AsExpandable() for EF
内容总结
以上是互联网集市为您收集整理的c# – 如何使用LINQ链接OR子句?全部内容,希望文章能够帮你解决c# – 如何使用LINQ链接OR子句?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。