c# - Fluent nHibernate映射问题

标签 c# nhibernate asp.net-mvc-3 fluent-nhibernate

我有这些表/类(示例):

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/

相关文章:

NHibernate Profiler 在骗我?

c# - 无法从用法推断类型参数

c# - 从自定义 AppDomain 运行代码

c# - 使用 linq 检查列表计数是否一致

nhibernate - 无法从NHibernate.Driver.SQLiteDriver创建驱动程序

c# - VS2010 + NUnit 加载程序集失败?

javascript - 使用javascript在MVC3中验证表单

c# - 在 3 个实体之间创建导航属性

sql - ASP.Net MVC3 SQL 连接字符串

c# - 检查是否已使用具有相同值的属性