我在 NHibernate 中有类似这种映射情况:
ClassA
mapping.Id(x => x.Id).Column("rowid").GeneratedBy.Identity().Unique();
ClassB
mapping.Id(x => x.Id).Column("rowid").GeneratedBy.Identity().Unique();
mapping.References<ClassA>(x => x.ClassA).Nullable();
当 NHibernate 生成数据库模式时,即使我在映射声明中指定了“Nullable”属性,它也会在这些表之间创建一个外键。显然,如果我尝试保存我的对象,我会收到外键约束错误,如果我手动从数据库中删除外键,它就像一个魅力。
如何告诉 NHibernate 在这种情况下不要创建外键脚本?
最佳答案
我认为您应该在 hbm.xml
映射文件中使用 foreign-key="none"
属性。
关于c# - 没有外键的 NHibernate 映射引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12432578/