97

Linq 中是否有一种方法可以用来构建 SQL 字符串,例如“...where (a=1) OR (a=2)”?

4

6 回答 6

197

您当然可以在 Where 子句(扩展方法)中执行此操作。但是,如果您需要动态构建复杂的查询,您可以使用PredicateBuilder

 var query = collection.Where( c => c.A == 1 || c.B == 2 );

或使用 PredicateBuilder

 var predicate = PredicateBuilder.False<Foo>();
 predicate = predicate.Or( f => f.A == 1 );
 if (allowB)
 {
    predicate = predicate.Or( f => f.B == 1 );
 }

 var query = collection.Where( predicate );
于 2010-01-20T13:19:17.610 回答
28

您可以在单个 where 子句中使用标准的 .NET 布尔运算符:

MyDataSource.Where(data => data.a == 'a' || data.a == 'b')
于 2010-01-20T13:18:46.457 回答
19

您使用与普通 C# 中所有相同的运算符 ===> || 用于“或” && 用于“和”等。

var something = from s in mycollection
                where s.something == 32 || 
                      s.somethingelse == 45 
                select s
于 2010-01-20T13:19:16.547 回答
1

在您的.Where()通话中使用标准布尔“或”运算符,||.

var query = items.Where(item => (item == 1 || item == 2));

Where 调用所做的所有事情都是对任何你想要的东西进行布尔比较,所以你可以用尽可能多的条件逻辑来填充它。

于 2010-01-20T13:21:46.527 回答
0

如果你不知道参数计数,你可以使用这个:

样本数据

var parameters= new List<string>{"a","d"};
var sampledata = new Dictionary<string,string>();
    sampledata["a"] = "A";
    sampledata["b"] = "B";
    sampledata["c"] = "C";
    sampledata["d"] = "D";

代码

var query = sampledata.AsQueryable();
var firstItemKey = sampledata.FirstOrDefault().Key;
var queryresult= sampledata.Where(x => x.Key == firstItemKey).AsQueryable();
foreach (var parameter in parameters.Skip(1))
{
    queryresult=queryresult.Concat(query.Where(x => x.Key == parameter));
}
var result = queryresult.ToList();
于 2018-04-05T08:17:05.353 回答
-1

这现在内置在 .net 中,不确定以前是否没有。给定一个现有的 Linq 查询,您可以添加一个接受字符串数组 (SearchStrings) 的 where 子句,并检查它们中的任何一个是否与您正在搜索的集合中的任何对象匹配。使用 ToLower() 只是确保您在 SQL 查询中避免区分大小写。

query.Where(i => SearchStrings.Any(s => i.ToLower().Contains(s.ToLower()));

您可以通过将数组中的所有单词与集合的对象匹配来对“and”谓词执行相同的操作。

query.Where(i => SearchStrings.All(s => i.ToLower().Contains(s.ToLower()));

在此示例中,i 与集合中的每个对象相关,s 与 SearchStrings 数组中的每个字符串相关。

于 2018-03-09T18:33:58.093 回答