Hibernate一对多映射是否与列表有效但不是一组?

时间:2010-08-27 01:17:49

标签: java hibernate orm hibernate-mapping

很抱歉打扰 - 也许这是一个非常简单的问题 - 但由于某种原因,下面的版本无法解析,而带有set的版本工作正常。事实上,如果我只是采取设置版本并用列表替换set我得到:

嵌套异常是org.hibernate.InvalidMappingException:无法从无效映射中解析映射文档

谢谢 米莎

    <!-- bi-directional one-to-many association to SpreadsheetImportTemplateColumn -->
    <list name="columns">
<!--
    <set name="columns" lazy="false" inverse="true"
        cascade="all-delete-orphan" sort="natural"
        order-by="voided asc, preferred desc, date_created desc">
-->
        <key column="template_id" not-null="true" />
<!--
        <one-to-many class="SpreadsheetImportTemplateColumn" />
    </set>
-->
    </list>

2 个答案:

答案 0 :(得分:5)

你说

  

而带有set的版本可以正常工作

此处列出DOCTYPE

<!ELEMENT list (
    meta*,
    subselect?,
    cache?,
    synchronize*,
    comment?,
    key, 
    (index|list-index), 
    (element|one-to-many|many-to-many|composite-element|many-to-any),
    loader?,sql-insert?,sql-update?,sql-delete?,sql-delete-all?,
    filter*
)>

你可以看到,列表元素需要索引或列表索引元素,一个关键元素,以及下列之一

  • 元素
  • 一个对多
  • 许多对多
  • 复合元件
  • 多对任何

这里是list-index DOCTYPE

<!-- Declares the type and column mapping for a collection index (array or list index, or key of a map). -->

<!ELEMENT list-index (column?)>
<!ATTLIST list-index column CDATA #IMPLIED>
<!ATTLIST list-index base CDATA "0">

所以你应该使用

<list name="columns">
    <key column="template_id" not-null="true"/>
    <list-index column="WHICH COLUMN SHOULD BE USED AS INDEX"/>
    <one-to-many class="SpreadsheetImportTemplateColumn" />
</list>

但是,如果您想使用列表而不是集合并且没有列表索引列,则可以使用行李。初始化如下

Collection<SpreadsheetImportTemplateColumn> columns = new ArrayList<SpreadsheetImportTemplateColumn>();

而是定义此映射

<bag name="columns">
     <key column="template_id" not-null="true"/>
     <one-to-many class="SpreadsheetImportTemplateColumn"/>
</bag>

答案 1 :(得分:0)

在Hibernate中,List必须指定索引列。

参见Hibernate documentation的第6.2.3节。