Отображение нескольких соединений в NHibernate - PullRequest
4 голосов
/ 31 октября 2011

Первый вопрос по Stackoverflow.

После использования JOIN для сопоставления свойства я пытаюсь использовать это свойство для другого объединения из третьей таблицы. Проблема состоит в том, что в сгенерированном SQL второй оператор JOIN использует правильный столбец, но из исходной таблицы, а не из второй таблицы.

Вот отображение -

 <class name="Core.Domain.NetHistoryMessage, Core" table="NHistoryIN" >
<id name="ID">
  <column name="ID"/>
  <generator class="assigned"/>
</id>     
<property name="RecipientDuns" unique="true">
  <column name="Recipient" unique="true"/>
</property>
<join table="DunsSites" optional="true" fetch="select">
  <key column="Duns" property-ref="RecipientDuns" />
  <property name="RecipientID" column="SiteID" unique="true" lazy="false"/>
</join>
<join table="Components"  optional="true" >
  <key column="ComponentID"   property-ref="RecipientID" />
  <property name="RecipientName" column="ComponentName" unique="true" lazy="false"/>
</join> 

Сгенерированный SQL -

SELECT this_.*, this_1_.SiteID as SiteID7_0_, this_2_.M_SNAME as M3_11_0_ 
FROM RNTransactionHistoryIN this_ 
left outer join DunsSites this_1_ on this_.Recipient=this_1_.Duns 
left outer join Components this_2_ on this_.SiteID=this_2_.ComponentID

Мне нужен следующий SQL -

SELECT this_.*, this_1_.SiteID as SiteID7_0_, this_2_.M_SNAME as M3_11_0_ 
FROM RNTransactionHistoryIN this_ 
left outer join DunsSites this_1_ on this_.Recipient=this_1_.Duns 
left outer join Components this_2_ on this_1_.SiteID=this_2_.ComponentID

Я использую NHibbernate 3.2.

Спасибо

1 Ответ

1 голос
/ 02 ноября 2011

Я попробовал то же самое, но так и не заработал.<join> предназначен для объединения только из исходной таблицы, а не каскадного.лучше объявить DunsSite как сущность и использовать <join> оттуда для компонентов.затем вы можете ввести Convenienceproperties в NetHistoryMessage.

public string ComponentName
{
    get { return DunsSite.ComponentName; }
    set { DunsSite.ComponentName = value; }
}
...