我有这些表/类(示例):
table FirstTable (
Id INTEGER NOT NULL DEFAULT AUTOINCREMENT,
Name VARCHAR(100) NOT NULL,
Document VARCHAR(20) NOT NULL
)
table SecondTable (
Id INTEGER NOT NULL,
Something VARCHAR(100) NULL,
FOREIGN KEY (Id) REFERENCES FirstTable (Id)
)
public class FirstClass {
public string Name { get; set; }
public string Document { get; set; }
public SecondClass SecondClass { get; set; }
}
public class SecondClass {
public string Something { get; set; }
public FirstClass FirstClass { get; set; }
}
映射是:
public class FirstClassMap : ClassMap<FirtsClass> {
Table("FirstTable");
Id(x => x.Id).GeneratedBy.Identity();
Map(x => x.Name);
Map(x => x.Document);
References(x => x.SecondClass, "Id").ForeignKey();
}
public class SecondClassMap : ClassMap<SecondClass> {
Table("SecondTable");
Id(x => x.Id).GeneratedBy.Foreign("FirstClass");
Max(x => x.Something);
HasOne(x => x.FirstClass).PropertyRef(x => x.SecondClass).Cascade.SaveUpdate();
}
FirstClass 可以有 (0,1) 个 SecondClass,而 SecondClass 可以有 (1,1) 个 FirstClass。
下面的代码返回错误“试图从空一对一属性分配 id:SecondClass”
var test = new SecondClass();
test.FirstClass = new FirstClass();
test.Something = "New test";
test.FirstClass.Name = "My name";
test.FirstClass.Document = "My document";
// ... commands to save.
最佳答案
NH 似乎试图先保存 SecondClass,但未能从尚未保存的 FirstClass 中获取生成的 ID。
尝试将 .Cascade.SaveUpdate()
移动到 FirstClassMap
中的 References
声明,并在 FirstClass 上调用保存命令。
关于c# - Fluent nHibernate映射问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6257124/