- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个非常简单的谓词生成器查询,效果很好。我们有一个要搜索的关键字列表,我们遍历这些关键字以查看是否有任何对象属性匹配。
var predicateSearchText = PredicateBuilder.False<Asset>();
List<string> separatedKeywords = keywords.Split(',').ToList();
foreach (string s in separatedKeywords)
{
if (s.Length > 0)
{
string temp = s;
predicateSearchText = predicateSearchText.Or(m => m.Notes.Contains(temp));
predicateSearchText = predicateSearchText.Or(m => m.Description.Contains(temp));
predicateSearchText = predicateSearchText.Or(m => m.DetailedDescription.Contains(temp));
predicateSearchText = predicateSearchText.Or(asset => asset.Keywords.Contains(temp));
predicateSearchText = predicateSearchText.Or(a => a.AssetFiles.Any(x => x.FileName.Contains(temp)));
}
}
...我做的更远:
var query = (from a in masterQuery.Where(predicateSearchText);
我得到了我需要的东西 - 仅过滤出那些具有我搜索过的关键字的内容。
我需要更改此设置,以便在我的实体的某个属性中查找所有关键字。因此“注释”字段必须包含要搜索的每个关键字,或者“描述”字段必须包含要搜索的所有关键字。我认为这涉及内部/外部谓词,但我还没有想出它。我试过的结果太多了,它应该只给我一个……其他实体不符合标准。我的问题很明显吗?我的关键字(其中 6 个)非常独特,我得到了 600 多个项目而不是 1...
var predicateSearchText = PredicateBuilder.False<Asset>();
var notesPred = PredicateBuilder.True<Asset>();
var descPred = PredicateBuilder.True<Asset>();
var detdescPred = PredicateBuilder.True<Asset>();
var keywordPred = PredicateBuilder.True<Asset>();
var filesPred = PredicateBuilder.True<Asset>();
foreach (string s in separatedKeywords.Where(xx=>xx.Length > 0))
descPred.And(m => m.Description.Contains(s));
foreach (string s in separatedKeywords.Where(xx => xx.Length > 0))
notesPred.And(m => m.Notes.Contains(s));
foreach (string s in separatedKeywords.Where(xx => xx.Length > 0))
detdescPred.And(m => m.DetailedDescription.Contains(s));
foreach (string s in separatedKeywords.Where(xx => xx.Length > 0))
keywordPred.And(m => m.Keywords.Contains(s));
foreach (string s in separatedKeywords.Where(xx => xx.Length > 0))
filesPred.And(a => a.AssetFiles.Any(x => x.FileName.Contains(s)));
predicateSearchText = predicateSearchText.Or(notesPred.Expand());
predicateSearchText = predicateSearchText.Or(descPred.Expand());
predicateSearchText = predicateSearchText.Or(detdescPred.Expand());
predicateSearchText = predicateSearchText.Or(keywordPred.Expand());
predicateSearchText = predicateSearchText.Or(filesPred.Expand());
然后我做我的:
var query = (from a in masterQuery.Where(predicateSearchText);
而且我得到的结果太多以至于谓词不正确。
最佳答案
我今天遇到了同样的问题。将 PredicateBuilder 实例化和 Where() 函数移到循环内,它将有效地与单独的关键字谓词进行 AND。
var predicateSearchText;
List<string> separatedKeywords = keywords.Split(',').ToList();
foreach (string s in separatedKeywords)
{
if (s.Length > 0)
{
predicateSearchText = PredicateBuilder.False<Asset>();
string temp = s;
predicateSearchText = predicateSearchText.Or(m => m.Notes.Contains(temp));
predicateSearchText = predicateSearchText.Or(m => m.Description.Contains(temp));
predicateSearchText = predicateSearchText.Or(m => m.DetailedDescription.Contains(temp));
predicateSearchText = predicateSearchText.Or(asset => asset.Keywords.Contains(temp));
predicateSearchText = predicateSearchText.Or(a => a.AssetFiles.Any(x => x.FileName.Contains(temp)));
Query = Query.AsExpandable().Where(predicateSearchText);
}
}
关于c# - Predicatebuilder group and or queries with inner outer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15980789/
我正在使用 PredicateBuilder 在我的操作中创建一个搜索/过滤器部分。在这里: [HttpPost] public ActionResult Test(int? cty,
我有代码: var predicate = PredicateBuilder.True(); predicate = predicate.And(x => x.value1 == "1"); p
我有这样一个实体: public class Product() { public string Name { get; set; } } 我想在 Name 属性上执行关键字搜索,以便对它们进
在我见过的谓词生成器的所有示例中,如果您要构建“和”表达式条件,它会显示一个带有 PredicateBuilder.True 的起始表达式,而 PredicateBuilder.False 如果您正在
我想在 Linq 语句中的 Join 中动态生成跨越多个表的谓词。在以下代码片段中,我想使用 PredicateBuilder 或类似的构造来替换以下代码中的“where”语句: 代替: public
List Prs = data.Products .Where(x=> x.ProductColors
我浏览了 PredicateBuilder来源及其实现让我很好奇。让我们看看 Or 方法的实现: public static Expression> Or (this Expression> expr
我正在为我的应用程序创建一个临时报告功能。我将 PredicateBuilder 用于“Where”部分,但现在当我尝试在“Select”部分中使用它时,我无法成功。 代码示例: IQuerya
我想使用“条件”对象动态构建 LinqToSQL 和 EntityFramework 查询子句,并在必要时利用 C# In a Nutshell PredicateBuilder (http://ww
我在使用 PredicateBuilder 将“Or Where”子句动态添加到 LINQ 语句时遇到问题。我将首先解释我要实现的目标。 我有一个倒排索引,用于存储来自一堆链接标题的关键字。我正在使用
我已经下载了 predicate builder并且很难让它与 Entity Framework 一起工作。这是我的代码:v_OrderDetail 是实体 var context = new Ord
我正在使用 PredicateBuilder 创建动态 Where 子句以从 DataTable 查询数据。我有一个字典,其中包含我需要搜索的列名和值。我只是遍历字典,如果键与列名匹配,则将该键和值添
C# in a Nutshell 有一个名为 PredicateBuilder 的免费类,它可以逐个构建 LINQ 谓词 here .这是向谓词添加新表达式的方法的摘录。有人可以解释一下吗? (我已经
我需要了解使用 PredicateBuilder .在几乎每个如何使用它的示例中,它们都显示如下代码: var predicate = PredicateBuilder.True(); if (!st
我有一个包含可变数量字段名称的列表。我想循环遍历此列表并创建一个谓词来过滤在该字段中具有值的所有记录。 foreach (var field in FieldNames) {
我提取了代码库的相关部分来进行说明。我真的被困在一些可能很简单的事情上。 仅供引用,在数据库中,p 和实体1 之间存在一对多关系。 predicate = PredicateBuilder.False
我一直在阅读 Joseph Albahari 关于 C# 4.0 的精彩书籍,我偶然发现了这门课: public static class PredicateBuilder {
我使用 linqToEntities并想添加 OR动态条件。 我知道there is a great library PredicateBuilder by brother Albahari它可以解决
我有一个关于 PredicateBuilder 的问题,我真的希望你能给我一些关于如何解决这个问题的建议。我将尝试对此进行解释。 我有一个案例,人们可以根据关键字搜索产品。每个关键字都属于一个关键字组
鉴于以下示例模型,我需要通过其所有者的属性查询 ITEMS。这是 Entity Framework 集,我想使用 LINQ 来完成。 public class Owner { public
我是一名优秀的程序员,十分优秀!