2011-01-17 1 views
4

Я ищу переход на Fluent NHibernate - единственная проблема, с которой я столкнулся до сих пор, заключается в том, что вы не можете указать имя внешнего ключа в объединенном сопоставлении подкласса.Fluent NHibernate - присоединившийся подкласс ForeignKey Name

У кого-нибудь есть решение для этого или обходной путь?

Я нашел this post, но предложение явно не было добавлено в код.

Я хотел бы, чтобы избежать настройки кода, если это возможно.

Любая помощь будет большим ...

Пример:

public class Product 
{ 
    public string Name { get; set; } 
} 

public class Hammer : Product 
{ 
    public string Description { get; set; } 
} 

public class ProductMap : ClassMap<Product, long> 
{ 
    public ProductMap() 
    { 
     Polymorphism.Implicit(); 
     Map(x => x.Name); 
    } 
} 

public class HammerMap : SubclassMap<Hammer> 
{ 
    public HammerMap() 
    { 
     Extends<Product>(); 
    } 
} 

Это создает что-то вроде:

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" default-access="field.camelcase-underscore" auto-import="false" default-cascade="none" default-lazy="true"> 
    <class xmlns="urn:nhibernate-mapping-2.2" dynamic-insert="true" dynamic-update="true" mutable="true" polymorphism="implicit" optimistic-lock="version" name="Domain.Product, Domain" table="Product"> 
    <id name="Id" type="System.Int64"> 
     <column name="Id" /> 
     <generator class="native"> 
     <param name="sequence">ProductId</param> 
     </generator> 
    </id> 
    <property name="Name" type="System.String"> 
     <column name="Name" /> 
    </property> 
    <joined-subclass name="Domain.Hammer, Domain" table="Hammer"> 
     <key> 
     <column name="Product_Id" /> 
     </key> 
     <property name="Description" type="System.String"> 
      <column name="Description" /> 
     </property> 
    </joined-subclass> 
    </class> 
</hibernate-mapping> 

Обратите внимание, что нет внешнего ключа имя, указанное в отображении НВМ файл - как в:

<joined-subclass name="Domain.Hammer, Domain" table="Hammer"> 
    <key column="Product_Id" foreign-key="FK_Hammer_Product"/> 
</joined-subclass> 

ответ

5

Попробуйте что-нибудь подобное

public class JoinedSubclassForeignKeyConvention : IJoinedSubclassConvention 
{ 
    public void Apply(IJoinedSubclassInstance instance) 
    { 
     instance.Key.ForeignKey(string.Format("FK_{0}_{1}", 
        instance.EntityType.Name, instance.Type.Name)); 
    } 
}