我有一个类User,它位于系统的核心模块中:
public class User
{
public virtual int Id {get; set;}
public virtual string Name {get; set; }
}
我还有一个类公司,它位于系统的另一个模块中,没有对核心模块的引用:
public class Company
{
public virtual int Id {get; set;}
public virtual string Name {get; set; }
public virtual int OwnerUserId {get; set;}
}
如何创建Company.OwnerUserId的映射作为数据库中User.Id的外键?再次注意:此映射不能引用“User”类。
答案 0 :(得分:-1)
这是一种解决方法,我不确定架构更新如何生成外键而没有映射引用来获取元数据。
您可以创建映射到同一个表的新实体:
public class LocalUser
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
}
public class Company
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
public virtual LocalUser OwnerUserId { get; set; }
}
public class LocalUserMap : ClassMap<LocalUser>
{
public LocalUserMap()
{
Table("[User]");
Id(x => x.Id).GeneratedBy.Identity();
Map(x => x.Name);
}
}