У меня есть проблема с моим файлом сопоставления, относящимся к отношениям один к одному, с составными первичными ключами, где имена полей ключей не совпадают.
Таблица 1:
<class entity-name="CompPkTest" table="compPkTest" catalog="data" mutable="true" polymorphism="implicit" dynamic-update="false" dynamic-insert="false" select-before-update="false" optimistic-lock="version">
<composite-id mapped="false" unsaved-value="undefined">
<key-property name="id1" type="int">
<column name="id1"/>
</key-property>
<key-property name="id2" type="int">
<column name="id2"/>
</key-property>
</composite-id>
<property name="details" type="string" unique="false" optimistic-lock="true" lazy="false" generated="never">
<column name="Details" length="500"/>
</property>
<one-to-one name="CompPkTestDetail" entity-name="CompPkTestDetail" constrained="false" embed-xml="true"/>
Table 2:
<class entity-name="CompPkTestDetail" table="compPkTestDetail" catalog="data" mutable="true" polymorphism="implicit" dynamic-update="false" dynamic-insert="false" select-before-update="false" optimistic-lock="version">
<composite-id mapped="false" unsaved-value="undefined">
<key-property name="idetail1" type="int">
<column name="idetail1"/>
</key-property>
<key-property name="idetail2" type="int">
<column name="idetail2"/>
</key-property>
</composite-id>
<one-to-one name="CompPkTest" entity-name="CompPkTest" constrained="true" embed-xml="true"/>
<property name="someDetail" type="string" unique="false" optimistic-lock="true" lazy="false" generated="never">
<column name="someDetail" length="300"/>
</property>
<property name="moreDetail" type="string" unique="false" optimistic-lock="true" lazy="false" generated="never">
<column name="moreDetail" length="300"/>
</property>
The problem is that when querying table 1, the "details" property is null. If I change the key-property names in CompPkTestDetail to be id1 and id2, (while leaving the column name unchanged), the relationship works as expected, and the query returns a value for "details".
Мои вопросы:
Является ли вышеприведенное сопоставление xml правильным способом создания этой ассоциации (с несовпадающими именами полей)?
Правильно ли hibernate навязывает, что имена полей должны совпадать, или это ошибка?
Обратите внимание, что в моем приложении нет классов для сущностей, а спящий режим находится в режиме карты. Мое приложение имеет полностью динамический доступ к (произвольным) базам данных, поэтому XML для сопоставлений создается во время выполнения.