我正在使用Fluent NHibernate试图提高使用旧数据库的Web应用程序的可测试性和可维护性,并且我在正确映射此结构时遇到了一些问题:
我有两个表真正代表域中的一个实体,所以我使用连接来映射它们,第三个表代表第二个实体。
数据库表:
[eACCT]
ACCT_ID
ACCT_NAME
[eREPORT_TYPE]
ACCT_ID
REPORT_NO
[eREPORT_TYPE_DESC]
REPORT_NO
REPORT_TYPE
实体:
public class Account
{
public virtual string AccountID { get; set; }
public virtual string AccountName { get; set; }
public virtual ReportType ReportType { get; set; }
}
public class ReportType
{
public virtual int Number { get; set; }
public virtual string Type { get; set; }
}
映射:
public AccountMap()
{
Table("eACCT");
Id(x => x.AccountID, "ACCT_ID");
Map(x => x.AccountName, "ACCT_NAME");
Join("eREPORT_TYPE", m =>
{
m.KeyColumn("ACCT_ID");
m.References(x => x.ReportType)
.Cascade.None()
.Column("REPORT_NO");
});
}
public ReportTypeMap()
{
Table("eREPORT_TYPE_DESC");
Id(x => x.Number)
.Column("REPORT_NO")
.GeneratedBy.Assigned();
Map(x => x.Type, "REPORT_TYPE");
}
这适用于我的获取,但是当我修改Account.ReportType.Number然后SaveOrUpdate()帐户时,我得到错误:'DataTest.Model.ReportType实例的标识符已从(old_value)更改为( NEW_VALUE)”
我想要做的就是修改Account对ReportType的引用,我认为通过在ReportType的引用上设置Cascade.None()属性,NHibernate也不会尝试保存ReportType实例,但我必须是误解了它的运作方式。我已经尝试制作ReportType ReadOnly(),引用ReportType ReadOnly()等,似乎没有任何帮助。
有什么想法吗?
答案 0 :(得分:0)
终于解决了这个问题。事实证明我并没有以NHibernate的方式思考这个问题。在我看来,我有一个新的ReportType.Number,所以我需要更新。实际上,我需要做的是使用新的ReportType.Number获取ReportType并设置Account.ReportType。这样做可以按预期工作。