отображение много-много в NHibernate - PullRequest
8 голосов
/ 27 апреля 2010

Я хочу создать отношения многие ко многим, используя NHibernate. Я не уверен, как отобразить их в файлах XML. Я еще не создал классы, но они будут просто базовыми POCO.

Таблица

Человек
personId
Имя

Компетенция
компетенция
Название

Person_x_Competency
personId
competencyId

Буду ли я создавать список в каждом POCO для другого класса? Затем сопоставить их с помощью файлов конфигурации NHibernate?

1 Ответ

23 голосов
/ 27 апреля 2010

Вы можете установить отношение «многие ко многим» для любого класса или даже для обоих. Это зависит от модели вашего домена. Если вы сопоставите его с обоими, один из них обратный.

class Person
{
  // id ...
  IList<Competency> Competencies { get; private set; }

  // you domain model is responsible to manage bidirectional dependencies.
  // of course this is not a complete implementation
  public void AddCompetency(Competency competency)
  {
    Competencies.Add(competency);
    competency.AddPerson(this);
  }
}

class Competency
{
  // id ...
  IList<Person> Persons { get; private set; }
}

Отображение:

<class name="Person">
  <id ....>
  <bag name="Competencies" table="Person_x_Competency">
    <key column="personId"/>
    <many-to-many class="Competency" column="competencyId"/>
  </bag>
</class>

<class name="Competency">
  <id ....>
  <bag name="Persons" table="Person_x_Competency" inverse="true">
    <key column="competencyId"/>
    <many-to-many class="Person" column="personId"/>
  </bag>
</class>

Делайте его двунаправленным, только если он вам действительно нужен.

Кстати: гораздо лучше сначала написать классы, а потом создать дизайн базы данных. База данных может быть экспортирована из файлов сопоставления. Это очень полезно.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...