我认为我只会从中读取(无写入)。该视图没有任何唯一键(不是事件复合键)。
因此,如何在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>();