Hibernate不插入作为复合FK一部分的字段

时间:2016-09-19 09:48:47

标签: java hibernate nhibernate-mapping

我有一个hibernate实体,它有两个多对一关联和复合外键,每个都有3个字段。两个键共有两个字段。有映射:

<class dynamic-insert='true' dynamic-update='true' entity-name='...' table='...'>
    <composite-id>
        <key-property name='FaultId' type='long' column='FAULT_ID'/>
        <key-property name='RowVersion' type='long' column='ROWVERSION'/>
    </composite-id>
    <many-to-one name='Pot' class='Pot'>
        <column name='SMELTER_ID' not-null='true'/>
        <column name='ROOM_ID' not-null='true'/>
        <column name='POT_ID' not-null='true'/>
    </many-to-one>
    <many-to-one name='Event' class='PotEventRef_NonGui'>
        <column name='EVENT_ID' not-null='true'/>
    </many-to-one>
    <many-to-one name='Shift' class='TimeShift' insert='false' update='false'>
        <column name='SMELTER_ID' not-null='true'/>
        <column name='ROOM_ID' not-null='true'/>
        <column name='TIMESHIFT' not-null='true'/>
    </many-to-one>
</class>

插入实体的代码:

session.persist(entry.getName(), entry.getData());

其中session - org.hibernate.Session,entry.getName() - String,entry.getData() - Map&lt; String,Object&gt;。

当我尝试插入此类的实体时,未插入TIMESHIFT字段。 (设置了Shift对象,所有值都正确)。什么可能是问题的根源?

1 个答案:

答案 0 :(得分:0)

尝试将更新值更改为true&amp;删除insert =&#39; false&#39;在XML中。

<many-to-one name='Shift' class='TimeShift' update='true'>