39

将来のある時点で、動的に生成されたレポートを再作成する方法が必要です。簡単に言うと、特定の linq クエリ (レポートごとに異なる) をデータベースに保存し、後で動的な Linq を使用してクエリを実行する必要があります。

これで問題ありませんが、式を文字列に変換する方法が見つかりません。

次のように:

Expression<Func<Product, bool>> exp = (x) => (x.Id > 5 && x.Warranty != false);

なる必要があります:

"Product.Id > 5 && Product.Warranty != false"

それを行う方法はありますか?

4

1 に答える 1

47

これは最良/最も効率的な方法ではないかもしれませんが、機能します。

Expression<Func<Product, bool>> exp = (x) => (x.Id > 5 && x.Warranty != false);

string expBody = ((LambdaExpression)exp).Body.ToString(); 
// Gives: ((x.Id > 5) AndAlso (x.Warranty != False))

var paramName = exp.Parameters[0].Name;
var paramTypeName = exp.Parameters[0].Type.Name;

// You could easily add "OrElse" and others...
expBody = expBody.Replace(paramName + ".", paramTypeName + ".")
                 .Replace("AndAlso", "&&");


Console.WriteLine(expBody);
// Output: ((Product.Id > 5) && (Product.Warranty != False))
于 2011-01-25T13:37:45.680 に答える