2013-06-18 2 views
2

Я пытаюсь преобразовать мои сопоставления FluentNHibernate в NHibernate Mapping By-code с помощью NHibernate 3.3.3. Целью является обновление до NHibernate 3.3.3 и сокращение количества распределяемых сборок.NHibernate много столбцов ManyToOne сопоставление с картографированием по коду

Однако, когда я компиляции и запуска, я получаю следующее исключение:

NHibernate.MappingException: Multi-колонки свойство не может быть отображен через один столбец API.

Отображение XML FluentNHibernate получает мои, выглядит так:

<many-to-one cascade="none" class="TextDto" fetch="join" lazy="false" name="Name" not-found="ignore"> 
    <column name="NameTextId" unique="false" /> 
    <column name="LanguageId" unique="false" /> 
</many-to-one> 

Вот мой новый К-код отображения:

this.ManyToOne(u => u.Name, c => 
{ 
    c.Cascade(Cascade.None); 
    c.Class(typeof(TextDto)); 
    c.Columns(
     x => 
     { 
      x.Name("NameTextId"); 
      x.Unique(false); 
     }, 
     x => 
     { 
      x.Name("LanguageId"); 
      x.Unique(false); 
     }); 
    c.Fetch(FetchKind.Join); 
    c.Lazy(LazyRelation.NoLazy); 
    c.NotFound(NotFoundMode.Ignore); 
    c.Unique(false); 
}); 

Это старая FluentNHibernate отображение:

References(x => x.Name) 
    .Columns("NameTextId", "LanguageId") 
    .Cascade.None() 
    .Fetch.Join() 
    .NotFound.Ignore() 
    .Not.Unique() 
    .Not.LazyLoad(); 

Для полноты собственности тип недвижимости вед:

public class TextDto 
{ 
    public TextCompositeId Id { get; set; } 
    public string PluralText { get; set; } 
    public string SingularText { get; set; } 
    public override bool Equals(object obj) 
    { 
     var text = (TextDto)obj; 
     if (text == null) return false; 
     return this.Id.Equals(text.Id); 
    } 
    public override int GetHashCode() 
    { 
     return this.Id.GetHashCode(); 
    } 
} 

И пример собственности в объекте:

public class CharacteristicValue 
{ 
    public CharacteristicValueCompositeId Id { get; set; } 
    public TextDto Name { get; set; } 
    public string LanguageIdentity { get; set; } 
    public string Value 
    { 
     get 
     { 
      string value = null; 
      if (this.ValueMultilingual != null) return this.ValueMultilingual.SingularText; 
      else if (!string.IsNullOrEmpty(this.ValueMeta)) return this.ValueMeta; 
      return value; 
     } 
    } 
    public TextDto ValueMultilingual { get; set; } 
    public string ValueMeta { get; set; } 
    public override bool Equals(object obj) 
    { 
     if (obj == null) return false; 
     if (object.ReferenceEquals(this, obj)) return true; 
     CharacteristicValue characteristicValue = obj as CharacteristicValue; 
     if (characteristicValue == null) return false; 
     if (this.Id != characteristicValue.Id) return false; 
     return true; 
    } 
    public override int GetHashCode() 
    { 
     return this.Id.GetHashCode(); 
    } 
} 

Итак, как я получаю XML-отображение я использовал, чтобы получить с FluentNHibernate, но с карт NHiberbate путем-кода?

ответ

2

В вашем отображении удалите c.Unique(false); с карты ManyToOne. Этот параметр применяется для каждого столбца.

this.ManyToOne(u => u.Name, c => 
{ 
    ... // the same as above 

    // c.Unique(false); // it is setting now related to columns 
}); 

И вы получите

<many-to-one name="Name" class="TextDto" fetch="join" lazy="false" not-found="ignore"> 
    <column name="NameTextId" unique="true" /> 
    <column name="LanguageId" /> 
</many-to-one> 

Если вы поменяете уникальность на одной из колонн:

x => 
{ 
    x.Name("NameTextId"); 
    x.Unique(true); // change here 
}, 

Уникальное ограничение будет добавлена ​​в эту колонку:

<column name="NameTextId" unique="true" /> 
+0

Спасибо, что получил отображение I ne редактор Я также заметил, что здесь вы также не можете использовать c.NotNullable (false). – Wietze

+0

Отлично, если это помогло! ;) –