0

これを関数化したい。db オブジェクトと MVC モデル オブジェクトを渡します。元のコードは次のとおりです。

var SomethingApproval = db.Somethings.AsQueryable();
var predicate = PredicateBuilder.True<Something>();
predicate = predicate.And(p => p.Approved == "N");
SomethingApproval = SomethingApproval.AsExpandable().Where(predicate);

こういう機能が欲しい

Function ApprovedItems (dbObject, modelObject)
{

var SomethingApproval = dbobject.AsQueryable();
var predicate = PredicateBuilder.True<modelObject>();
predicate = predicate.And(p => p.Approved == "N");
SomethingApproval = SomethingApproval.AsExpandable().Where(predicate);
return SomethingApproval
}
4

1 に答える 1

1

ここで手足に出かけます...それは一般的な質問だと思います

public IQueryable<T> ApprovedItems<T>(DbObject db)
    where T : IApprovable
{
    var query = db.Set<T>();
    return query.Where(p => p.Approved == "N");
}

public interface IApprovable
{
    //By the way I do not Approve of an 
    //approve flag with type of string
    string Approved {get;}
}
于 2013-06-25T07:54:19.667 に答える