2013-07-22 3 views
2

동적 조건에 따라 데이터를로드하려고합니다.LINQ에서 동적 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

이 어떻게 처리 하는가?

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); 

나중에 그것을 사용 : : 람다보다는 문자열의 형태로

+0

코드를 올바르게 포맷하십시오. 지금은 읽기가 어렵습니다. –

+0

답변을 보려면이 블로그를 참조하십시오. http://weblogs.asp.net/scottgu/archive/2008/01/07/dynamic-linq-part-1-using-the-linq-dynamic-query-library.aspx – Ehsan

+0

오류가 발생하면 LINQ to SQL이 아닌 EF를 사용하고 있음을 나타내는 오류가 나타납니다. 이 경우 태그를 수정하십시오. 문자열을 사용하려면 대신 [ObjectQuery 's Where] (http://msdn.microsoft.com/en-us/library/bb338811.aspx) 메서드를 사용하는 것이 좋습니다. –

답변

8

Where 기다리고 조건, 당신은 당신의 코드를 약간 (아래 단지 아이디어를) 리팩토링 할 수 있도록

... 
join b in query 
... 
+0

@Anderi 그것은'암시 적으로 'System.Data.CntCommPreference>'형식으로 System.Linq.IQueryable '형식을'System.Data.Entity.DbSet '으로 변환 할 수 없습니다. 명시 적 변환이 존재합니다 (캐스트가 누락 되었습니까?) – James123

+0

@ James123, 유형을 명시 적으로 지정하십시오. 예를 들어 업데이트 된 답변을 참조하십시오. – Andrei

0

이 블로그보기 : Scott. 문제를 정렬하는 데 도움이됩니다.

0

표시되는 오류는 LINQ to SQL이 아닌 EF를 사용하고 있음을 나타냅니다. 이 경우 태그를 수정하십시오. 문자열을 사용하려면 DBSet을 사용하는 대신 ObjectQuery's Where 메서드를 사용하는 것이 좋습니다. 또는 EntitySQL을 사용하여 전체 쿼리를 작성할 수 있습니다.