0

我在hibernate中映射列表时遇到困难。我想知道你对我的课程,地图和数据库方案的想法。如果一切正常,我将不胜感激对抛出异常的一些帮助。提前致谢 !hibernate映射列表<CustomClass> - ClassCastException

我有以下类别:

public class AuditEntry { 

    private long id; 
    private String typeLigne; 
    private String famille; 
    private String user; 
    private String libelle ; 
    private String processName; 
    private String caseId; 
    private Date dateCreation = null; 
    private List<AuditEntryStringMap> libelles; 

    /* Getters and setters generated automatically... */ 
} 

public class AuditEntryStringMap { 

    private long id ; 
    private String key ; 
    private String value ; 

    public AuditEntryStringMap(String key, String value) { 
     this.key = key ; 
     this.value = value ; 
    } 
     /* Getters and setters generated automatically... */ 
} 

我HBM文件如下:

<class name="AuditEntryStringMap" table="AUDIT_I18N"> 

     <cache usage="read-write" include="all" /> 
     <id name="id" type="long"> 
      <column name="AUDIT_I18N_ID"></column> 
      <generator class="sequence" > 
      <param name="sequence">AUDIT_I18N_SEQ</param> 
      </generator> 
     </id> 

     <property name="key" column="KEY_" /> 
     <property name="value" column="VALUE_"/> 

</class> 
<class name="AuditEntry" table="AUDIT"> 

     <cache usage="read-write" include="all" /> 
     <id name="id" type="long"> 
      <column name="AUDIT_ID"></column> 
      <generator class="sequence" > 
      <param name="sequence">AUDIT_SEQ</param> 
      </generator> 
     </id> 

     <property name="typeLigne" column="TYPELIGNE" /> 

     <property name="libelle" column="LIBELLE" /> 

     <property name="user" column="USERNAME" /> 

     <property name="processName" column="PROCESSNAME" /> 

     <property name="caseId" column="CASE_ID" /> 

     <property name="dateCreation" insert="false" update="false"> 
      <column name="DCRE" sql-type="date" default="sysdate"></column> 
     </property> 

     <list name="libelles" table="AUDIT_I18N"> 
      <key> 
       <column name="FK_AUDIT_ID" sql-type="number(19,0)" /> 
      </key> 
      <index type="string" column="KEY_" /> 
      <element type="string" column="VALUE_" /> 
     </list> 
    </class> 

最后,我的sql脚本如下:

create sequence AUDIT_SEQ; 
create sequence AUDIT_I18N_SEQ; 

create table AUDIT (
    AUDIT_ID  number(19,0) not null, 
    TYPELIGNE varchar2(255 char), 
    LIBELLE  varchar2(255 char), 
    USERNAME  varchar2(255 char), 
    CASE_ID  varchar2(255 char), 
    PROCESSNAME varchar2(255 char), 
    DCRE   date default sysdate, 
    primary key (AUDIT_ID)); 

create table AUDIT_I18N (
    AUDIT_I18N_ID  number(19,0) not null, 
    KEY_    varchar2(255 char), 
    VALUE_   varchar2(255 char), 
    FK_AUDIT_ID  number(19, 0), 
    primary key (AUDIT_I18N_ID)) 

ALTER TABLE AUDIT_I18N add constraint FK_AUDIT_I18N foreign key (FK_AUDIT_ID) references AUDIT; 

Hibernate的生成在提交异常之前执行以下查询:

Hibernate: select AUDIT_SEQ.nextval from dual 
Hibernate: insert into AUDIT (TYPELIGNE, LIBELLE, USERNAME, PROCESSNAME, CASE_ID, AUDIT_ID) values (?, ?, ?, ?, ?, ?) 
Hibernate: insert into AUDIT_I18N (FK_AUDIT_ID, KEY_, VALUE_) values (?, ?, ?) 

例外:

com.bpm.domain.AuditEntryStringMap cannot be cast to java.lang.String 

时GenericDaoHibernate.save(T实体)被调用时发生。

回答

0

使用一组而不是列表问题解决了......而这在映射:

<set name="libelles" lazy="extra" cascade="all-delete-orphan"> 
      <cache usage="read-write" include="all" /> 
      <key column="FK_AUDIT_ID"/> 
      <one-to-many class="AuditEntryStringMap" /> 
</set> 

而且,我对AuditEntryStringMap HBM没有在hibernate.cfg.xml引用。但仅凭这一点就无法解决列表标签的问题。

半分辨率所以......如果有人知道它为什么不能与列表一起工作,将不胜感激全分辨率。