映射Fluent NHibernate,其中主键也应该是外键

时间:2011-11-18 14:22:27

标签: c# nhibernate fluent-nhibernate

我有一个像这样的用户对象:

public class User
{
    public Guid UserId { get; set; }
    public string UserName { get; set; }
    ...
}

这是在nhibernate中流畅映射的:

public class UserMap : ClassMap<User>
{
    public UserMap()
    {
        Id(x => x.UserId).Column("UserId");
        Map(x => x.UserName).Not.Nullable();
        ...
    }
}

我正在尝试构建一个与用户对象分开的凭据块,因此密码和salt不会在用户类中携带,如下所示:

public class UserCredential
{
    public User User { get; set; }
    public byte[] Password { get; set; }
    public string Salt { get; set; }
}

...但我无法弄清楚如何正确映射这个。最终,在数据库中,我希望在UserId表中看到UserCredentials列,它既是主键,又是Users表的外键。 Users表不应引用UserCredentials表。我该怎么写ClassMap<UserCredential>班?

2 个答案:

答案 0 :(得分:7)

这似乎是one-to-one关系,因此将使用FNH中的HasOne进行映射。

实施例

    public UserCredentialMap()
    {
        Id(x => x.Id)
            .Column("UserId")
            .GeneratedBy.Foreign("User");

        HasOne(x => x.User).Constrained();
    }

您也可以像这样映射它:

public UserCredentialMap()
{
    Id(x => x.Id, "UserId");

    References(x => x.User, "UserId")
            .Not.Update()
            .Not.Insert();
}

答案 1 :(得分:0)

由于您不想给Credentials它自己的主键,在我看来,您真正想要的是Componentmore details)。

这意味着Credential数据与User数据存储在同一个表中,但会在您的域中建模为单独的对象,这是User类的属性。