FluentNhibernate映射字典外键保持空

时间:2012-12-06 09:21:07

标签: c# nhibernate fluent-nhibernate

我有一个简单的Fluent-NHibernate映射让我很头疼!我正在尝试为其中一个实体映射字典,但其FK仍然为空。

这是实体代码:

public class Person
{
    public Person()
    {
        PhoneNumbers = new Dictionary<string, Phone>();
    }

    public virtual int Id { get; set; }
    public virtual string Name { get; set; }
    public virtual IDictionary<string, Phone> PhoneNumbers { get; set; }
}

public class Phone
{
    public virtual int Id { get; set; }
    public virtual string Type { get; set; }
    public virtual string Number { get; set; }
}

现在,这是映射:

public class PersonClassMap : ClassMap<Person>
{
    public PersonClassMap()
    {
        Id(x => x.Id).GeneratedBy.Identity();
        Map(x => x.Name);
        HasMany(x => x.PhoneNumbers).AsMap(y => y.Type).Cascade.All();
    }
}

public class PhoneClassMap : ClassMap<Phone>
{
    public PhoneClassMap()
    {
        Id(x => x.Id).GeneratedBy.Identity();
        Map(x => x.Type);
        Map(x => x.Number);
    }
}

最后,这是我正在做的测试:

    static void Main(string[] args)
    {
        ConfigureSessionFactory();

        using (var session = _sessionFactory.OpenSession())
        {
            var john = new Person();
            john.Name = "John";

            Phone home = new Phone
                             {
                                 Type = "Home",
                                 Number = "12345"
                             };

            john.PhoneNumbers.Add(home.Type, home);

            session.Save(john);
        }
    }

出于某种原因,当我查看数据库时,电话记录的Person_id仍然为空,当我从数据库中加载该人时,PhoneNumbers字典仍为空。

为什么呢?以及如何解决这个问题?我的映射错误是什么?

1 个答案:

答案 0 :(得分:0)

最后通过添加交易来解决此问题。我不知道为什么会这样(这实际上让我很伤心),但确实如此。

using (var session = _sessionFactory.OpenSession())
{
    var transaction = session.BeginTransaction();
    john.Name = "John";

    Phone home = new Phone
                     {
                         Type = "Home",
                         Number = "12345"
                     };
     john.PhoneNumbers.Add(home.Type, home);
     session.Save(john);
     transaction.Commit();
}

希望对你有所帮助,因为我花了3个小时才能做到这一点。