Сопоставление составных ключей в Fluent NHibernate - PullRequest
40 голосов
/ 15 января 2009

Я новичок в беглом NHibernate. Теперь я сталкиваюсь с одной проблемой с отображением составных ключей. Кто-нибудь может указать URL или образец, пожалуйста?

Ответы [ 4 ]

50 голосов
/ 15 января 2009

Есть метод CompositeId.

public class EntityMap : ClassMap<Entity>
{
  public EntityMap()
  {
      CompositeId()
      .KeyProperty(x => x.Something)
      .KeyReference(x => x.SomethingElse);
  }
}
5 голосов
/ 13 мая 2009

если это ваш первый класс

public class EntityMap : ClassMap<Entity>
{
  public EntityMap()
  {
    UseCompositeId()
      .WithKeyProperty(x => x.Something)
      .WithReferenceProperty(x => x.SomethingElse);
  }
}

вот второй со ссылкой на Entity

public class SecondEntityMap : ClassMap<SecondEntity>
    {
      public SecondEntityMap()
      {
        Id(x => x.Id);

        ....

        References<Entity>(x => x.EntityProperty)
          .WithColumns("Something", "SomethingElse")
          .LazyLoad()
          .Cascade.None()
          .NotFound.Ignore()
          .FetchType.Join();

      }
    }
4 голосов
/ 30 июня 2015

Еще одна вещь, на которую следует обратить внимание: вы должны переопределить методы Equals и GetHashCode для объекта, использующего CompositeId. Если принять файл соответствия принятых ответов, ваша сущность будет выглядеть следующим образом.

public class Entity
{
   public virtual int Something {get; set;}
   public virtual AnotherEntity SomethingElse {get; set;}


   public override bool Equals(object obj)
    {
        var other = obj as Entity;

        if (ReferenceEquals(null, other)) return false;
        if (ReferenceEquals(this, other)) return true;
        return other.SomethingElse == SomethingElse && other.Something == Something;
    }

    public override int GetHashCode()
    {
        unchecked
        {
            return (SomethingElse.GetHashCode()*397) ^ Something;
        }
    }

}
1 голос
/ 07 декабря 2012

Может возникнуть необходимость в объектах с составными идентификаторами, объектах, которые отображаются в таблицы с составными первичными ключами, состоящими из множества столбцов. Столбцы, составляющие этот первичный ключ, обычно являются внешними ключами других таблиц.

public class UserMap : ClassMap<User>
{      
   public UserMap()
   {
        Table("User");

        Id(x => x.Id).Column("ID");

        CompositeId()
          .KeyProperty(x => x.Id, "ID")
          .KeyReference(x => x.User, "USER_ID");

        Map(x => x.Name).Column("NAME");               

        References(x => x.Company).Column("COMPANY_ID").ForeignKey("ID");
    }
}

Для более подробной информации: http://www.codeproject.com/Tips/419780/NHibernate-mappings-for-Composite-Keys-with-associ

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