我想用 nHibernate 和 QueryOver 为 List() 创建一个通用方法。我已经到了想要添加连接的地步,但是如果不指定要加入的泛型类型,我认为我无法做到……这不会使它变得如此动态,因为必须声明每个泛型。有没有地方有一个动态的连接列表?下面的代码:
public static IList<T> QueryOver<T>(
Dictionary<Expression<Func<T, object>>, JoinType> joins,
List<Expression<Func<T, bool>>> predicates,
Dictionary<Expression<Func<T, object>>, System.Web.UI.WebControls.SortDirection> sortList,
int? maxResults
) where T : class
{
IList<T> results;
IQueryOver<T, T> query;
results = null;
// open the session
using (ISession session = OpenSession())
{
// begin a transaction
using (ITransaction transaction = session.BeginTransaction())
{
try
{
// declare the query
query = session.QueryOver<T>();
// joins
if (joins != null && joins.Count > 0)
{
foreach (KeyValuePair<Expression<Func<T, object>>, JoinType> join in joins)
{
// required to specify the type in the format query.JoinQueryOver<SubType>(join.Key, join.Value)
// BUT this means that it's not so dynamic because each SubType would have to be specified in the method call, yes?
query = query.JoinQueryOver(join.Key, join.Value);
}
}
// apply the where clauses
if (predicates != null && predicates.Count > 0)
{
foreach (Expression<Func<T, bool>> predicate in predicates)
{
query = query.Where(predicate);
}
}
// apply the sorting
if (sortList != null && sortList.Count > 0)
{
foreach (KeyValuePair<Expression<Func<T, object>>, System.Web.UI.WebControls.SortDirection> sort in sortList)
{
if (sort.Value == System.Web.UI.WebControls.SortDirection.Ascending)
{
query = query.OrderBy(sort.Key).Asc;
}
else
{
query = query.OrderBy(sort.Key).Desc;
}
}
}
// max results
if (maxResults.HasValue && maxResults.Value > 0)
{
query = (IQueryOver<T, T>)query.Take(maxResults.Value);
}
results = query.List();
// no errors, commit the transaction
transaction.Commit();
}
catch (Exception ex)
{
// error, rollback
transaction.Rollback();
// throw the exception and let the business logic deal with it
throw ex;
}
}
}
return results;
}