微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 映射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; }
}

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

解决方法

这似乎是一对一的关系,因此将使用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();
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐