使用Nhibernate一次插入两个相关的表

时间:2012-10-08 08:55:29

标签: nhibernate

我有两个实体,比如

   public class Person
        {
            public int PersonId { get; set; }
            public string Name { get; set; }
            public int DataId { get; set; }
    }
     public class Data
        {
                public int DataId { get; set; }
        public string details { get; set; }
        public int PersnId{ get; set; }
}

如你所见,两个表都是相互关联的。我想要一个解决方案,一次在两个表中插入数据。我1插入人,2插入数据,然后更新人,它的工作,但我正在寻找消除更新的方法。 我对人员表的映射:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" namespace="TestNhibrinate" assembly="TestNhibrinate">
    <class name="TestNhibrinate.Entites.Person" table="Person" lazy="false">
        <id name="PersonId" column="PersonId" type="int" >
            <generator class="identity" />
        </id>
        <property name="Name" column="Name" type="String" length="50" />
        <many-to-one name="Adress" class="TestNhibrinate.Entites.Adress" column="AdressId"/>        
    </class>
</hibernate-mapping>

和数据的相同映射。

1 个答案:

答案 0 :(得分:0)

您的实体应如下所示:

       public class Person
            {
             public Person()
             {
                DataCollection = new List<Data>();
             }
                public int PersonId { get; set; }
                public string Name { get; set; }
                public int DataId { get; set; }
                public IList<Data> DataCollection{get;set;}

                public void AddData(Data item)
                {
                   if(!DataCollection.Contains(item))
                   {
                      DataCollection.Add(item);
                   }
                }
        }
         public class Data
            {
                    public int DataId { get; set; }
            public string details { get; set; }
            public Person Person{ get; set; }
    }

这样您就可以创建从Person到Data的一对多关系。如果在添加一些数据后保存人员实体,则数据也将保留。这取决于您的级联选项。

我不确定如何使用XML映射来映射它,因为我总是使用Fluent或Auto映射。