- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为我的应用程序创建一个临时报告功能。我将 PredicateBuilder 用于“Where”部分,但现在当我尝试在“Select”部分中使用它时,我无法成功。
代码示例:
IQueryable<User> usersQuery = db.Users.AsQueryable();
var where = PredicateBuilder.True<User>();
//sample for the users query
where = where.And(p => p.Enabled);
var selectOrders = PredicateBuilder.True<UserOrder>();
//sample for a query inside user orders
selectOrders = selectOrders.And(p => p.Amount > 10);
usersQuery = usersQuery.Where(where); //work
var query = (from a in usersQuery
select new
{
FirstName = a.FirstName,
TotalOrders = a.UserOrders.Where(selectOrders).Count() //could not compile
}).AsQueryable();
我觉得你做不到
.Select("new (TotalOrders = UserOrders.Where(BetAmount > @0).Count()")
在 DynamicLinq 中,但我无法使用它,因为我在“select”中调用了一些 sql 用户定义的函数,而 DynamicLinq 不支持它。
最佳答案
我认为这里的问题实际上在于,Linq to SQL 不支持您的查询所需的子查询。这就是为什么您的案例中的导航属性 UserOrders
没有实现 IQueryable
并且无法在其上运行查询。
我可能是错的。但这证明我是对的:http://blog.robustsoftware.co.uk/2009/01/why-linq-to-sql-is-not-proper-orm.html
您应该使用更好的 ORM,例如 Entity Framework。
关于c# - 在选择中使用 PredicateBuilder,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5594891/
我正在使用 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
我是一名优秀的程序员,十分优秀!