2016-05-05 4 views
1

Linqを使用してMongoDB C#Driverクエリに式の動的リストを渡そうとしています。例えばORM、しかし、MongoDBのクエリに適用されるエラーになる...(FYI:私もLinqKitのPredicateBuilderを使用しています)動的Linq述語はC#MongoDBドライバで "Unsupported Filter"エラーをスローします

// 
// I create a List of Expressions which I can then add individual predicates to on an 
// "as-needed" basis. 
    var filters = new List<Expression<Func<Session, Boolean>>>(); 

// 
// If the Region DropDownList returns a value then add an expression to match it. 
// (the WebFormsService is a home built service for extracting data from the various 
// WebForms Server Controls... in case you're wondering how it fits in) 
    if (!String.IsNullOrEmpty(WebFormsService.GetControlValueAsString(this.ddlRegion))) 
    { 
     String region = WebFormsService.GetControlValueAsString(this.ddlRegion).ToLower(); 
     filters.Add(e => e.Region.ToLower() == region); 
    } 

// 
// If the StartDate has been specified then add an expression to match it. 
    if (this.StartDate.HasValue) 
    { 
     Int64 startTicks = this.StartDate.Value.Ticks; 
     filters.Add(e => e.StartTimestampTicks >= startTicks); 
    } 

// 
// If the EndDate has been specified then add an expression to match it. 
    if (this.EndDate.HasValue) 
    { 
     Int64 endTicks = this.EndDate.Value.Ticks; 
     filters.Add(e => e.StartTimestampTicks <= endTicks); 
    } 

// 
// Pass the Expression list to the method that executes the query 
    var data = SessionMsgsDbSvc.GetSessionMsgs(filters); 

GetSessionMsgs()メソッドは、データサービスのクラスで定義されます。.. 。

public class SessionMsgsDbSvc 
{ 

    public static List<LocationOwnerSessions> GetSessionMsgs(List<Expression<Func<Session, Boolean>>> values) 
    { 
     // 
     // Using the LinqKit PredicateBuilder I simply add the provided expressions 
     // into a single "AND" expression ... 
      var predicate = PredicateBuilder.True<Session>(); 
      foreach (var value in values) 
      { 
       predicate = predicate.And(value); 
      } 

     // 
     // ... and apply it as I would to any Linq query, in the Where clause. 
     // Additionally, using the Select clause I project the results into a 
     // pre-defined data transfer object (DTO) and only the DISTINCT DTOs are returned 
      var query = ApplCoreMsgDbCtx.Sessions.AsQueryable() 
       .Where(predicate) 
       .Select(e => new LocationOwnerSessions 
        { 
         AssetNumber = e.AssetNumber, 
         Owner = e.LocationOwner, 
         Region = e.Region 
        }) 
       .Distinct(); 

      var data = query.ToList(); 

      return data; 
    } 
} 

LinqKit PredicateBuilder I simplを使用するとy与えられた式を1つの "AND"式に追加し、Where()句の任意のLinqクエリと同様に適用します。さらに、Select()節を使用して、定義済みのデータ転送オブジェクト(DTO)に結果を投影し、DISTINCT DTOだけが返されます。

私はTelerik ORMコンテキストエンティティのコレクションに逆行すると、この技術は、一般的に動作します...しかし、私はMongoのマニュアルコレクションに対してこれを実行すると、私は次のエラーを取得する...

サポートされていないフィルタ:起動(E =>(e.Region.ToLower()== "中央")、 {文書})

私は上不明確だカバーの下で起こって何かが確かにあります。 MongoDB documentationのためのC#のドライバでは、私は「...

を、以下の注意を発見したスカラーを投影するときのMongoDBは、アグリゲーションパイプラインからその 出力を必要とするため、ドライバは、生成されたフィールド名を持つ 文書にスカラをラップします文書であること」

しかし正直なところ、この問題に関連しているのか、それともこの問題に関係しているのかわかりません。このエラーの「{document}」の表示は、それが関連している可能性があることを示唆しています。

追加の考えや洞察力は非常に高く評価されます。私はthis postを見つけたが、これまでに受け入れたソリューションは、私がやっているよりもはるかに異なっているかわからない...今2日のよりよい部分のために、この上

を立ち往生されて。 MongoDBのドライバがでうまく動作するIQueryable<T>インターフェイス上Func<T, bool>方法を使用してトリガする

答えて

2

.Where(predicate.Compile())

+0

ありがとう、それは私のために働いた。私はこの答えが下落した理由を理解していません。 – Ronnie

関連する問題