3

鉴于以下情况QueryOver

UserProfile userProfileAlias = null;
Pegfile pegfileAlias = null;
var q = Session.QueryOver(() => pegfileAlias)
        .JoinAlias(() => pegfileAlias.UserProfile, () => userProfileAlias);

我想通过交换使以下语句动态化

q = q.OrderBy(() => userProfileAlias.Forename).Asc;

(OrderBy(Expression<Func<object>>或 ( OrderBy(Expression<Func<T, object>>))

q = q.OrderBy(GetMemberExpression(userProfileAlias, "Forename")).Asc;

我从另一个帖子借来得到

private Expression<Func<object>> GetMemberExpression(UserProfile instance, string propertyName)
        {
            var arg = Expression.Constant(instance, typeof(UserProfile));
            var body = Expression.Convert(Expression.PropertyOrField(arg, propertyName), typeof(UserProfile));
            var lambda = Expression.Lambda<Func<object>>(body);
            return lambda;
        }

但这不起作用,我得到:

System.InvalidOperationException
No coercion operator is defined between types 'System.String' and 'Pegfect.Domain.PegDudes.UserProfile'.

我想我可能需要匹配以下信号:

OrderBy(Expression<Func<UserProfile,object>>)

如何GetMemberExpression变成退货?

4

1 回答 1

4

您的版本不起作用的原因是 NHibernate 实际上并没有为在JoinAlias. 它只是一个正在被解析的令牌。这意味着当您想在其他地方使用它时,它必须是完全相同的变量。
为此,您需要保存别名表达式并使用其主体来检索该变量:

UserProfile alias = null;
Expression<Func<object>> aliasExpression = () => alias;
session.QueryOver<Pegfile>()
       .JoinAlias(x => x.UserProfiles, aliasExpression)
       .OrderBy(GetMemberExpression(aliasExpression, "Forename")).Asc
       .List();

private Expression<Func<object>> GetMemberExpression(
                                     Expression<Func<object>> aliasExpression,
                                     string property)
{
    var propertyExpression = Expression.Property(aliasExpression.Body,
                                                 typeof(UserProfile), property);
    var body = Expression.Convert(propertyExpression, typeof(object));

    var result = Expression.Lambda<Func<object>>(body);
    return result;
}
于 2013-01-14T13:26:56.937 回答