1

抱歉,如果之前已回答过此问题。我试过谷歌但找不到答案。

目前我有课

public class User
{
    public virtual string Username { get; set; }
    public virtual string Name { get; set; }

    public virtual ISet<User> Teamleaders { get; set;}
    public virtual ISet<User> Staff { get; set;}
}

teamLeaders 存储该用户拥有的所有团队负责人。员工存储团队负责人拥有的所有员工。

这是一个多对多的关系。

目前我的 XML 文件如下所示

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
               assembly="SDReward"
               namespace="SDReward.Domain">
  <class name="User">
    <id name="Username" />
    <property name="Name" />

  </class>
</hibernate-mapping>

我已经使用以下数据。它从 teamleaderstaff 表中获取数据

<set name="Teamleaders" table="teamleaderstaff">
  <key column="TeamleaderId" />
  <many-to-many column="UserId" class="User" />
</set>

<set name="Staff" table="teamleaderstaff">
  <key column="UserId" />
  <many-to-many column="TeamleaderId" class="User" />
</set>

但是当我进行插入时,它会将它们插入到数据库中...例如,如果我向用户添加 1 个团队负责人并将该用户添加为团队负责人的员工,它会使用相同的数据进行 2 次插入。

4

1 回答 1

2

在您的情况下,多对多的映射可能看起来像

<set name="Teamleaders" table="teamleaderstaff" lazy="true">
  <key column="UserId"/>
  <many-to-many class="User" column="TeamleaderId"/>
</set>


<set name="Staff" table="teamleaderstaff" lazy="true" inverse="true" >
  <key column="TeamleaderId"/>
  <many-to-many class="User" column="UserId"/>
</set>

1)不同之处在于<key column映射。

2)在 期间insert,其中一个集合(Staff)被标记为inverse="true",因此不会触发双重插入

于 2013-06-08T18:30:07.000 回答