2

編集:クラス名を変更しました。

次の一連のクラスで Fluent NHibernate (v 1.0.0.614) 自動マッピングを使用しています (Entity は、S#arp アーキテクチャ フレームワークで提供される基本クラスです)。

public class Car : Entity
{
    public virtual int ModelYear { get; set; }
    public virtual Company Manufacturer { get; set; }
}

public class Sedan : Car
{
    public virtual bool WonSedanOfYear { get; set; }
}

public class Company : Entity
{
    public virtual IList<Sedan> Sedans { get; set; }
}

これにより、次の構成が生成されます (hbm.xml に書き込まれます)。

   <class name="Company" table="Companies">
     <id name="Id" type="System.Int32" unsaved-value="0">
       <column name="`ID`" />
       <generator class="identity" />
     </id>
     <bag cascade="all" inverse="true" name="Sedans" mutable="true">
       <key>
           <column name="`CompanyID`" />
       </key>
       <one-to-many class="Sedan" />
     </bag>
   </class>

   <class name="Car" table="Cars">
     <id name="Id" type="System.Int32" unsaved-value="0">
       <column name="`ID`" />
       <generator class="identity" />
     </id>
     <property name="ModelYear" type="System.Int32">
       <column name="`ModelYear`" />
     </property>
     <many-to-one cascade="save-update" class="Company" name="Manufacturer">
       <column name="`CompanyID`" />
     </many-to-one>
     <joined-subclass name="Sedan">
       <key>
          <column name="`CarID`" />
       </key>
       <property name="WonSedanOfYear" type="System.Boolean">
          <column name="`WonSedanOfYear`" />
       </property>
     </joined-subclass>
   </class>

ここまでは順調ですね!しかし、今は醜い部分です。生成されたデータベース テーブル:

Table: Companies
Columns: ID (PK, int, not null)

Table: Cars
Columns: ID (PK, int, not null)
         ModelYear (int, null)
         CompanyID (FK, int, null)


Table: Sedan
Columns: CarID (PK, FK, int, not null)
         WonSedanOfYear (bit, null)
         CompanyID (FK, int, null)

Company の FK が 1 つではなく、2 つ取得できます。

会社の FK を 1 つだけ取得するにはどうすればよいですか? 自動マッピングをオーバーライドしますか? コンベンションを開催しますか?それともこれはバグですか?あなたの考えは大歓迎です。

4

1 に答える 1

0

あなたの痛みが分かります。

時間がなくなったので、この時点で次のことを行いました

public class JoinedSubclassConvention : IJoinedSubclassConvention
{
    public void Apply(IJoinedSubclassInstance instance)
    {
        switch (instance.EntityType.Name)
        {
            case "Business":
                instance.Key.ForeignKey("FK_Business_Customer");
                break;
            case "Person":
                instance.Key.ForeignKey("FK_Person_Customer");
                break;
            case "StaffMember":
                instance.Key.ForeignKey("FK_StaffMember_Customer");
                break;
        }
    }
}
于 2010-03-27T05:01:18.847 に答える