0

问题总结

我正在尝试使用复合键映射多对一。到目前为止,我还没有找到另一个有帮助的问题。我知道如何一对一映射到复合键,但它不允许我映射多对一。

下面你会看到 bhrvJournalDAO 有一个 store_nbr 列,它映射到 transAcctgBuTxtDAO acctg_bu_id。如何点击复合键并告诉它只使用 acctgBuId?我没有国家代码(这是复合键的第二部分)。

从这里

<hibernate-mapping>
<class name="com.acctg.BhrvJournalDAO" table="transpo_acctg:bhrv_journal">
    <id name="jeId" column="je_id">
        <generator class="native"/>
    </id>
    <property name="bhrvInvoiceId" column="bhrv_invoice_id"/>
    <property name="storeNbr" column="store_nbr"/>
    <property name="loadId" column="load_id"/>

  <many-to-one name="transAcctgBuTxt" class="TransAcctgBuTxtDAO" insert="false" update="false" cascade="all">
              <column name="store_nbr"></column>
  </many-to-one>
</class>

到这里

<hibernate-mapping>
<class name="TransAcctgBuTxtDAO"    table="transpo_acctg:trans_acctg_bu_txt">
    <composite-id name="transAcctgBuTxtPKDAO"   class="TransAcctgBuTxtPKDAO">
        <key-property name="acctgBuId" column="acctg_bu_id"/>
        <key-property name="languageCode" column="language_code"/>
    </composite-id>
    <property name="acctgBuAbbr" type="java.lang.String">
        <column name="acctg_bu_abbr" />
    </property>
    <property name="acctgBuDesc" type="java.lang.String">
        <column name="acctg_bu_desc" />
    </property>
    <many-to-one name="transAcctgBuDAO"  class="TransAcctgBuDAO" not-null="false" 
        insert="false" update="false" not-found="ignore" fetch="select">
        <column name="acctg_bu_id" />
    </many-to-one>
 </class>

映射

  <many-to-one name="transAcctgBuTxt" class="TransAcctgBuTxtDAO" 
        insert="false" update="false" cascade="all">
              <column name="store_nbr"></column>
  </many-to-one>

复合键示例

 <one-to-one name="transAcctgBuTxt" class="TransAcctgBuTxtDAO" property-
       ref="transAcctgBuTxtPKDAO.acctgBuId"> 
        <column name = "store_nbr">
 </one-to-one>

错误

Foreign key (FK47A121BB6617227C:transpo_acct:bhrv_journal [store_nbr])) 
must have same number of columns as the referenced primary 
key (transpo_acct:trans_acctg_bu_txt [acctg_bu_id,language_code])

提前致谢

4

1 回答 1

0

由于 TransAcctgBuTxtDAO 具有 2 列的复合 id,因此您需要提供这两个值来唯一标识一个实体,周期。也许您可以重新考虑 BhrvJournalDAO 和 TransAcctgBuTxtDAO 之间是否真的是多对一的关系。Mabye 它实际上是多对多的。

于 2013-04-01T03:52:42.403 回答