0

維持する必要がある Session.QueryOver があり、次のような列名の魔法の文字列を削除したいと考えています。


return Session.QueryOver<T>()
    .SelectList(list => list
        .Select(Projections.SqlGroupProjection(
            "CANDIES(" + MagicalStringForColumnName +") As [Candies]",
            "CANDIES(" + MagicalStringForColumnName + ")",
            new[] { "Candies" },
            new IType[] { NHibernateUtil.Int32 }))

そして、私はそれが次のようになりたい:

return Session.QueryOver<T>()
    .SelectList(list => list
        .Select(Projections.SqlGroupProjection(
            "CANDIES(" + Session.GetColumnNameFromMappedProperty(propInfo.Name) +") As [Candies]",
            "CANDIES(" + Session.GetColumnNameFromMappedProperty(propInfo.Name) + ")",
            new[] { "Candies" },
            new IType[] { NHibernateUtil.Int32 }))
4

1 に答える 1

1

alias と SqlFunction を使用すると、魔法の文字列の代わりに式を使用できることがわかりました。

        object a = null;

        return Session.QueryOver<T>()
               .SelectList(l =>
                   l.Select(
                   Projections.GroupProperty(
                   Projections.SqlFunction("CANDIES", NHibernateUtil.Int32, Projections.Property(expression))
                   )).WithAlias(() => a)
于 2013-08-07T11:19:09.647 に答える