我有一个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对象,所有值都正确)。什么可能是问题的根源?
答案 0 :(得分:0)
尝试将更新值更改为true&amp;删除insert =&#39; false&#39;在XML中。
<many-to-one name='Shift' class='TimeShift' update='true'>