Ria*_*its 1 c# nhibernate nhibernate-criteria
我想查询一个nhibernate映射类,但结果应该是一个未映射的对象.映射和未映射的类如下所示:
[Class(NameType = typeof(ClassA)]
public class ClassA
{
[Cache(0, Usage = CacheUsage.ReadWrite)]
[Id(1, Name = "Id", UnsavedValue = null)]
[Generator(2, Class = "native")]
public virtual long? Id { get; set; }
[Property]
public virtual string PropertyA { get; set; }
[Property]
public virtual string PropertyB { get; set; }
}
public class ClassB
{
public string PropertyA { get; set; }
public string PropertyB { get; set; }
public int Number { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
我用这个方法得到我想要的结果:
public ICollection<ClassB> Group()
{
var result =
Session.CreateCriteria(typeof(ClassA)).SetProjection(
Projections.ProjectionList().Add(Projections.RowCount(), "Number")
.Add(Projections.GroupProperty("PropertyA"))
.Add(Projections.GroupProperty("PropertyB")));
return
(result.List().Cast<IList>().Select(
entry =>
new ClassB {
Number = (int)entry[0],
PropertyA = (string)entry[1],
PropertyB = (string)entry[2]
}
)).ToList();
}
Run Code Online (Sandbox Code Playgroud)
这工作正常,但使用criteria-api是不是有更直接的方法呢?
是的只是做
result.SetResultTransformer(Transformers.AliasToBean<ClassB>());
result.List<ClassB>();
Run Code Online (Sandbox Code Playgroud)
您还需要将属性投影包装为别名
Projections.Alias(Projections.GroupProperty("PropertyA"), "PropertyA")
| 归档时间: |
|
| 查看次数: |
944 次 |
| 最近记录: |