- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我开始使用 LinqKit的 PredicateBuilder使用 Linq 表达式无法实现的 OR 条件创建谓词。
我面临的问题是,如果我以 PredicateBuilder.True<MyEntity>()
开头它返回所有行 如果我以 PredicateBuilder.False<MyEntity>()
开头它返回非行,除了我使用的表达式!看下面的代码:
var pre = PredicateBuilder.True<MyEntity>();
pre.And(m => m.IsActive == true);
using (var db = new TestEntities())
{
var list = db.MyEntity.AsExpandable().Where(pre).ToList();
dataGridView1.DataSource = list;
}
它应该返回 IsActive == true 的行,但它返回所有行!
我已经尝试了 PredicateBuilder.True
的所有可能组合| PredicateBuilder.False
与 And
| Or
方法,但没有一个有效!
最佳答案
And
扩展方法不会修改 原始谓词 - 它返回一个代表原始谓词 AND< 的新谓词
ed 与指定的谓词一起。
实际上,您的操作不会更改 pre
变量引用的谓词,这意味着根据您是否将原始谓词初始化为 ,您最终得到所有记录或没有记录true
或 false
。
尝试:
var pre = PredicateBuilder.True<MyEntity>();
pre = pre.And(m => m.IsActive);
如果您计划将谓词OR
在一起,请记住以false
初始谓词开始。
var pre = PredicateBuilder.False<MyEntity>();
pre = pre.Or(m => m.IsActive);
关于c# - LinqKit PredicateBuilder 返回所有或非行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15325245/
我正在使用 LinqKit允许动态组合表达式的库。 对于编写 Entity Framewok 数据访问层来说,这是一种纯粹的幸福,因为可以选择性地重用和组合多个表达式,从而实现代码的可读性和高效性。
我有 2 个类: public class Employee { public int Id {get;set;} public string Name {get;set;} } pu
我开始使用 LinqKit的 PredicateBuilder使用 Linq 表达式无法实现的 OR 条件创建谓词。 我面临的问题是,如果我以 PredicateBuilder.True() 开头它返
我一直在使用LinqKit创建通用查询相当长一段时间。 一直困扰我的一件事是,您总是必须测试过滤器中发送的值是否有效。 例如:假设我有一个字符串过滤器。条件可以是 Equal、StartsWith、E
我一直在使用LinqKit创建通用查询相当长一段时间。 一直困扰我的一件事是,您总是必须测试过滤器中发送的值是否有效。 例如:假设我有一个字符串过滤器。条件可以是 Equal、StartsWith、E
我正在为我的应用程序执行搜索。搜索有效,除非用户的搜索通过搜索相关实体进行级联。我调试了代码并测试了 Entity Framework 生成的 SQL。我发现问题是 Contains() 在 SQL
给定一个简单的父/子类结构。我想使用 linqkit 在父项上应用子 lambda 表达式。我还希望通过实用方法提供 Lambda 表达式。 public class Foo { public
我正在尝试使用 LinqKit AsExpandable在我的 EfCore2.0项目,我遇到了这个问题,其中 Includes不起作用。 在尝试调试时,我下载了 LinqKit来自 github 的
我一直在尝试合并 LINQKit然而,我在共享数据访问层中遇到了障碍。使用 ExpandableQuery 构造嵌套查询时,表达式解析器无法正确解包 ExpandableQuery 并构造有效的 SQ
如何从 LinqKit.ExpandableQuery 返回 SQL ? 我正在使用 stevefenton.co.uk 中的代码但它似乎失败了 private static System.Data.
这是我想做的: class MyDbContext : DbContext { private static Expression> myExpression1 = x => /* somet
我在尝试执行使用 PredicateBuilder 动态构建的查询时遇到问题。 我能够构建查询,但是在执行查询本身时,我得到以下“TypeLoadException”... 运行时: return c
在 Entity Framework Core 中使用谓词生成器时,我收到以下错误。 The source IQueryable doesn't implement IAsyncEnumerable.
我想使用 LinqKit 的 PredicateBuilder 并将谓词传递给相关模型的 .Any 方法。 所以我想建立一个谓词: var castCondition = PredicateBuild
我正在使用 LinqKit PredicateBuilder (http://www.albahari.com/nutshell/predicatebuilder.aspx) 作为执行搜索的方法。这就
我正在使用 LinqKit,我想编写一个谓词,其中代码必须调用一个普通的 bool 方法,如下所示: var predicate = PredicateBuilder.False(); var pre
我正在使用 EntityFramework 和 LinqKit构建被翻译成 SQL 的表达式树。我们还使用规范模式来组织我们的查询。 几乎所有领域对象都需要通过描述执行查询,但在某些类中,属性称为“名
我正在使用 LinqKit (http://www.albahari.com/nutshell/linqkit.aspx) 有没有一种方法可以让下面的代码在不定义具体类的情况下工作? 尝试使用 LIN
我正在尝试动态构造一个类似于下面的表达式,我可以在其中使用相同的比较函数,但可以传入被比较的值,因为该值是从属性“higher-up”传递的' 在查询中。 var people = People
我不完全理解为什么 select 中的嵌套调用在 LinqKit 中不起作用,想知道是否有人能够帮助我理解。 我的问题: 首先让我列出有效的方法。 假设我们有三个数据库对象: public class
我是一名优秀的程序员,十分优秀!