我认为我只会从中读取(无写入)。该视图没有任何唯一键(不是事件复合键)。

因此,如何在NHibernate中映射此视图而不触及该视图?我不想在视图中添加新列以为我生成唯一身份。有没有办法映射此视图并在NHibernate端生成标识列?

我可以在实体类中生成GUID,例如:

public class MyViewClass
{
    private Guid _id = new Guid();
    public virtual Guid Id { get { return _id; } set { _id = value; } }
}


但是如何使映射起作用?以下代码不起作用:

public class MyViewClass: ClassMapping<MyViewClass>
{
    public MyViewClass()
    {
        Mutable(false);
        Id(x => x.Id, m => m.Generator(Generators.Guid));
    }

}


它希望查看Id列并抛出:

System.Data.SqlClient.SqlException: Invalid column name 'Id'.


顺便说一句,我正在使用NHibernate 3.2和代码映射。

最佳答案

更新:要在LINQ中使用它,请将所有列都映射为CompositeId和Mutable(false),然后使用默认实现覆盖Equals和GetHashCode。

public class MyViewClass
{
    public override bool Equals(object obj)
    {
        return base.Equals(obj);
    }

    public override int GetHashCode()
    {
        return base.GetHashCode();
    }
}




原始答案:

如果您不想插入/更新它,我根本不会映射它

public class MyViewClass
{
    public virtual string Prop1 { get; set; }
    public virtual int Prop2 { get; set; }
}

var viewObjects = session.CreateSQLQuery("SELECT col1 as Prop1, col2 as Prop2 FROM MyView")
    .SetResultTransformer(Transformers.AliasToBean<MyViewClass>())
    .List<MyViewClass>();

07-28 01:49
查看更多