我有两个多对一关联和复合外键的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。
当我试图插入这个类的实体时,没有插入TIMESHIFT字段。(Shift对象已设置,且所有值都正确)。什么可能是问题的根源?
发布于 2016-09-20 12:14:31
尝试将update value更改为true &删除XML中的insert='false‘。
<many-to-one name='Shift' class='TimeShift' update='true'>https://stackoverflow.com/questions/39570110
复制相似问题