2

こんにちは、c# で winform アプリケーションを作成します。

私はEF5を使用してデータベースを操作しています。

データをデータグリッドビューにバインドするために、このイベントを実行する Bind() メソッドを持つ BindingSource からコンポーネントを作成しました。

private object bindingSourceTbl1_DataSourceBinding(object sender, EventArgs e)
{
    using (SampleDbEntities dbo = new SampleDbEntities())
    {
      return(from x in dbo.Tbl1
             where x.Id == (int)comboBoxPerson.SelectedValue
             select x).Take(1000).ToList();
    }
}

私のデータベースには多くの大きなデータがあるため、データの一部をフェッチします。そして、一致レコードを取得するために検索を使用します。このために、グリッド内の各列をフィルター処理するためのテキスト ボックスを作成する SearchPanel コンポーネントを作成しました。

今、式ツリーをパラメーターとしてイベントに送信して、次のように where 句に結合したいと考えています。

private object bindingSourceTbl1_DataSourceBinding(object sender, EventArgs e,Expression whereClause)
{
    using (SampleDbEntities dbo = new SampleDbEntities())
    {
      return(from x in dbo.Tbl1
             where x.Id == (int)comboBoxPerson.SelectedValue && whereClause
             select x).Take(1000).ToList();
    }
}

しかし、式ツリービルダーメソッドはコンポーネントコードに存在し、プロジェクトの DbContext にアクセスできず、コンポーネントに fieldNames があるだけで、すべてのテーブルに対して 1 つのメソッドだけを記述したいと考えています。

これは私がのように戻ることができないことを意味します

Expression< Func< AnyDbSet,bool>>

そして、私はそれを行う方法がわかりませんか?

ありがとう

4

3 に答える 3

7

だけが必要な場合は、 (どこでとは で動作する任意のブール式) が と論理的に同じで &&あることを認識すると役に立ちます。これが意味することは、コードを次のように書き直すことができるということです。coll.Where(x => a(x) && b(x))a(x)b(x)xcoll.Where(x => a(x)).Where(x => b(x))

List<Tbl1Type> GetTbl1Values(Expression<Func<Tbl1Type, bool>> whereClause)
{
    using (SampleDbEntities dbo = new SampleDbEntities())
    {
        return dbo.Tbl1
            .Where(x => x.Id == (int)comboBoxPerson.SelectedValue)
            .Where(whereClause)
            .Take(1000).ToList();
    }
}

||さらに複雑な組み合わせをサポートする必要がある場合は、 LINQKitを使用できます。

これにより、プロパティ名から式を作成するという問題が残ります。Expressionそのためにタイプのメソッドを使用できます。たとえば、次のようなものです。

static Expression<Func<T, bool>> CreateWhereClause<T>(
    string propertyName, object propertyValue)
{
    var parameter = Expression.Parameter(typeof(T));
    return Expression.Lambda<Func<T, bool>>(
        Expression.Equal(
            Expression.Property(parameter, propertyName),
            Expression.Constant(propertyValue)),
        parameter);
}
于 2013-11-14T14:49:54.280 に答える
0

Joseph Albahari による PredicateBuilder の使用をお勧めします。http://www.albahari.com/nutshell/predicatebuilder.aspxで見つけることができます。

于 2013-11-14T10:00:00.133 に答える
0

dynamic linqを使用できます。以下に例を示します。

var result = northwind.Products
     .Where("CategoryID = 3 AND UnitPrice > 3")
     .OrderBy("SupplierID");

===

private object bindingSourceTbl1_DataSourceBinding(object sender, EventArgs e,Expression whereClause)
{
    using (SampleDbEntities dbo = new SampleDbEntities())
    {
         var q = from x in dbo.Tbl1
             where x.Id == (int)comboBoxPerson.SelectedValue && whereClause
             select x);
         q = q.Where(whereClause)// your must reference dynamic linq library.
                                 //whereClause is expression
               .Take(100);
         return q.ToList();

    }

}

于 2013-11-14T06:14:30.033 に答える