LINQ中的动态where子句?

我正在尝试根据Dynamic where条件加载数据。

string tempQry = string.Empty; if (!string.IsNullOrEmpty(cusid) && !string.IsNullOrEmpty(mktid)) tempQry = "x=>x.MarketID==" + mktid + "&& x.MasterCustomerID==" + cusid; if (string.IsNullOrEmpty(cusid)) tempQry = "x=>x.MarketID==" + mktid; if (string.IsNullOrEmpty(mktid)) tempQry = "x=>x.MasterCustomerID==" + cusid; _lstOptInInterest = new LinkedList( (from a in _lstOptInInterest join b in _marketoEntities.CustCommPreferences.Where(tempQry) on new { CODE = a.Code, SUBCODE = a.SubCode } equals new { CODE = b.Option_Short_Name, SUBCODE = b.Option_Short_Subname } into leftGroup from b in leftGroup.DefaultIfEmpty() select new OptInInterestArea() { Code = a.Code, SubCode = a.SubCode, SubCodeDescription = a.SubCodeDescription, CodeDescription = a.CodeDescription, PrevOptIn = b != null && b.OptedIn == true }).ToList()); 

它给出了编译错误Where(tempQry)

'System.Data.Entity.DbSet' does not contain a definition for 'Where' and the best extension method overload 'System.Linq.Queryable.Where(System.Linq.IQueryable, System.Linq.Expressions.Expression<System.Func>)' has some invalid arguments

怎么办呢?

等待lambda而不是字符串forms的条件,所以你必须稍微重构一下你的代码(下面只是一个想法):

 IQueryable query = _marketoEntities.CustCommPreferences.AsQueryable(); if (!string.IsNullOrEmpty(cusid)) query = query.Where(x => x.MasterCustomerID == cusid); if (!string.IsNullOrEmpty(mktid)) query = query.Where(x => x.MarketID == mktid); 

然后使用它:

 ... join b in query ... 

看斯科特的这篇博客。 它应该可以帮助您解决问题

您看到的错误似乎表明您使用的是EF而不是LINQ to SQL。 如果是这种情况,请更正您的标签。 如果要使用字符串,请考虑使用ObjectQuery的Where方法而不是使用DBSet。 或者,您可以使用EntitySQL构建整个查询。