2013-04-28 69 views
2

我有两个具有一对一关系的复合ID的表。表一:PK列:column1,column2 表二:PK列:column3,column4。当关键名称不同时休眠一对一关联

列有不同的名称。我必须将column1映射到column3,将column2映射到column4。 表1(父表)声明:

<class name="com.java.TABLE1" table="TABLE1"> 
     <composite-id name="TABLE1_pk" class="com.tc4.dal.TABLE1_PK"> 
      <key-property name="COLUMN1" column="COLUMN1" /> 
      <key-property name="COLUMN2" column="COLUMN3" /> 
     </composite-id> 
...remaining properties declarations... 

<one-to-one name="TABLE2" class="com.tc4.dal.TABLE2" 
      cascade="save-update, delete"> 
      <key column="COLUMN3" property-ref="COLUMN1" /> 
      <key column="COLUMN4" property-ref="COLUMN2" /> 
</one-to-one> 
</class> 

表2(子表)映射

<class name="com.java.TABLE2" table="TABLE2"> 
     <composite-id name="TABLE2_pk" class="com.tc4.dal.TABLE2_PK"> 
      <key-property name="COLUMN3" column="COLUMN3" /> 
      <key-property name="COLUMN4" column="COLUMN4" /> 
     </composite-id> 
</class> 

,同时启动应用程序,获得以下异常

Caused by: org.hibernate.InvalidMappingException: Could not parse mapping document from resource com/JAVA/TABLE1.hbm.xml 
    Caused by: org.xml.sax.SAXParseException: The content of element type "one-to-one" must match "(meta*,formula*)". 
    at org.apache.xerces.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:196) 
    at org.apache.xerces.util.ErrorHandlerWrapper.error(ErrorHandlerWrapper.java:132) 
    at org.apache.xerces.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:390) 

如何给予一对一的关联在这种情况下映射文件。

Regards, Naresh。

+0

你可以向其他映射详细资料,如你是如何映射的复合ID?与 2013-04-28 08:23:54

+0

根据问题'LNBCPRODHDRP0'具有键列名称'BC_BANK_ID,BC_BRANCH_ID,BC_PRODUCT_NBR',但在您的情况下'LNBCPRODHDRP0_pk'指的是'LC_BANK_ID,LC_BRANCH_ID,LC_PRODUCT_NBR'也请编辑原始问题以添加此信息。不要在评论中提供代码。 – 2013-04-28 08:59:26

+0

@ rahul maindargi,我编辑了我的问题。你能否检查 – 2013-04-29 04:58:24

回答

1

将它们在父表中的子表复合键列重命名已解决此问题。 详细阐释: - - 父表(TABLE1):

<class name="com.java.TABLE1" table="TABLE1"> 
      <composite-id name="TABLE1_pk" class="com.tc4.dal.TABLE1_PK"> 
       <key-property name="COLUMN1Prop" column="COLUMN1" /> 
       <key-property name="COLUMN2Prop" column="COLUMN3" /> 
    </composite-id> 
    .... remaining properties 
    </class> 

//作为TABLE1是具有组合大关键,需要为TABLE1创建主键POJO

public class TABLE1_PK { 
    public String COLUMN1Prop; 
    public String COLUMN2Prop; 
    } 

TABLE1实体:

public class TABLE1{ 
    // declare PK 
    private TABLE1_PK TABLE1_pk; 
// getters and setters and remaining properties 
} 
  • 子表(表2):

    <class name="com.java.TABLE2" table="TABLE2"> 
            <composite-id name="TABLE2_pk" class="com.tc4.dal.TABLE2_PK"> 
             <key-property name="COLUMN1Prop" column="COLUMN3" /> 
             <key-property name="COLUMN2Prop" column="COLUMN4" /> 
          </composite-id> 
          .... remaining properties 
         </class> 
    

子实体PK

public class TABLE2_PK{ 
// here property names should be defined as parent Entity properties 
     public String COLUMN1Prop; 
     public String COLUMN2Prop; 
.. getters and setters 
} 
1

与注释U可以这样实现它。在表1

@OneToOne(targetEntity = TABLE2.class, fetch = FetchType.LAZY) 
    @JoinColumns(value = { 
     @JoinColumn(name = "COLUMN1", referencedColumnName = "COLUMN3"), 
     @JoinColumn(name = "COLUMN2", referencedColumnName = "COLUMN4") }) 
    TABLE2 table2 

使用XML试试这个,让我知道

<class name="com.java.TABLE1" table="TABLE1"> 
     <composite-id name="TABLE1_pk" class="com.tc4.dal.TABLE1_PK"> 
      <key-property name="COLUMN1PROP" column="COLUMN1" /> 
      <key-property name="COLUMN2PROP" column="COLUMN3" /> 
     </composite-id> 
...remaining properties declarations... 

<one-to-one name="TABLE2" class="com.tc4.dal.TABLE2" 
      cascade="save-update, delete"> 
      <key column="COLUMN1PROP" property-ref="COLUMN3PROP" /> 
      <key column="COLUMN2PROP" property-ref="COLUMN4PROP" /> 
</one-to-one> 
</class> 

<class name="com.java.TABLE2" table="TABLE2"> 
     <composite-id name="TABLE2_pk" class="com.tc4.dal.TABLE2_PK"> 
      <key-property name="COLUMN3PROP" column="COLUMN3" /> 
      <key-property name="COLUMN4PROP" column="COLUMN4" /> 
     </composite-id> 
</class> 

或者

<class name="com.java.TABLE1" table="TABLE1"> 
     <composite-id name="TABLE1_pk" class="com.tc4.dal.TABLE1_PK"> 
      <key-property name="COLUMN1PROP" column="COLUMN1" /> 
      <key-property name="COLUMN2PROP" column="COLUMN3" /> 
     </composite-id> 
...remaining properties declarations... 

<one-to-one name="TABLE2" class="com.tc4.dal.TABLE2" 
      cascade="save-update, delete"> 
      <key column="COLUMN1" property-ref="COLUMN3PROP" /> 
      <key column="COLUMN2" property-ref="COLUMN4PROP" /> 
</one-to-one> 
</class> 

<class name="com.java.TABLE2" table="TABLE2"> 
     <composite-id name="TABLE2_pk" class="com.tc4.dal.TABLE2_PK"> 
      <key-property name="COLUMN3PROP" column="COLUMN3" /> 
      <key-property name="COLUMN4PROP" column="COLUMN4" /> 
     </composite-id> 
</class> 

让我knwo哪一个工作。 :)

+1

Hi Rahul,谢谢你的回复。我正在使用基于xml的映射。我已经尝试过你的第二种情况,这仍然会导致异常。我怀疑你的第一个案件是否会工作,因为,这里列标签应该是指一列(<键列=“COLUMN1PROP”属性-REF =“COLUMN3PROP” />) – 2013-04-29 14:05:31

+0

@拉胡尔迈恩达尔吉,有任何意见或任何其他建议? – 2013-05-03 08:43:01

+0

以及我也在搜索并通过hibernate文档。我找到的东西:) – 2013-05-04 12:49:06