【问题标题】:Dynamic where clause in LINQ?LINQ中的动态where子句?
【发布时间】:2015-04-12 16:04:27
【问题描述】:

我正在尝试根据动态 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<OptInInterestArea>(
        (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<Market.Data.CustCommPreference>' does not contain a definition for 'Where' and the best extension method overload 'System.Linq.Queryable.Where<TSource>(System.Linq.IQueryable<TSource>, System.Linq.Expressions.Expression<System.Func<TSource,bool>>)' has some invalid arguments

如何处理?

【问题讨论】:

  • 请正确格式化您的代码。现在很难阅读。
  • 请参阅此博客以获取答案weblogs.asp.net/scottgu/archive/2008/01/07/…
  • 您看到的错误似乎表明您使用的是 EF 而不是 LINQ to SQL。如果是这种情况,请更正您的标签。如果要使用字符串,请考虑改用ObjectQuery's Where 方法。

标签: c# linq linq-to-sql


【解决方案1】:

Where 以 lambdas 而不是字符串的形式等待条件,因此您必须稍微重构您的代码(只是下面的一个想法):

IQueryable<CustCommPreference> 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
...

【讨论】:

  • @Anderi 它说Cannot implicitly convert type 'System.Linq.IQueryable&lt;SPE.Marketo.Data.CustCommPreference&gt;' to 'System.Data.Entity.DbSet&lt;Market.Data.CustCommPreference&gt;'. An explicit conversion exists (are you missing a cast?)
  • @James123,尝试明确指定类型。有关示例,请参阅更新的答案。
【解决方案2】:

请参阅Scott 的此博客。它应该可以帮助您解决问题

【讨论】:

    【解决方案3】:

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

    【讨论】:

      猜你喜欢
      • 2010-10-25
      • 2023-03-29
      • 2012-02-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-01-15
      相关资源
      最近更新 更多