在JSP中循环使用Hibernate多对多

时间:2012-03-03 19:49:54

标签: java database hibernate jsp hibernate-mapping

我在使用@ManyToMany关系时遇到了一些问题。我理解使用@JoinTable而不是实际创建一个ManyToMany类,它非常直接。

使用这种方法,在JSP中循环通过集合非常简单。我从这里复制了我的例子:http://www.mkyong.com/hibernate/hibernate-many-to-many-relationship-example-annotation/假设我们有一组包含类别集合的股票。

<c:forEach var="stock" items="${parentItem.stocks}">
    <div>Stock id: ${stock.id}</div>
    <c:forEach var="category" items="${stock.categories}">
        <div style="padding-left:15px">Category id: ${category.id}</div>
    </c:forEach>
</c:forEach>
Output:
Stock id: 1
    Category id: 1
    Category id: 2
Stock id: 2
    Category id: 1
    Category id: 3
....

我的项目要求我的ManyToMany表包含自定义列。我的理解是我需要在代码中定义关联表,而不是。所以现在父项包含StocksCategories的集合,其中包含股票和类别。因此,根据我的要求并查看定义ManyToMany表的示例:http://www.mkyong.com/hibernate/hibernate-many-to-many-example-join-table-extra-column-annotation/它改变了很多东西。所以现在循环使用会变得有点棘手。

<c:forEach var="currentStockCategory" items="${parentItem.stocksCategories}">
    <div>${currentStockCategory.stock.id}</div>
    <c:forEach var="innerStockCategory" items="${currentStockCategory.stock.stocksCategories}"> // back up the tree
        <div>${innerStockCategory.category.id}</div>
    </c:forEach>
</c:forEach>
Output:
Stock id: 1
    Category id: 1
    Category id: 2
Stock id: 1
    Category id: 1
    Category id: 2
Stock id: 2
    Category id: 1
    Category id: 3
Stock id: 2
    Category id: 1
    Category id: 3
....

正如您所看到的那样,它循环遍历stocksCategories关联表中的每个条目。我不希望这样,我需要它像第一个一样显示。从技术上讲,类别列表仍然是该库存对象的一部分,但是如何让它在jsp中以这种方式显示呢?恢复数据库结构的整个想法感觉不对。

我无法查询库存集合并单独存储它,我必须将它连接到父对象。

我一直在争夺这个约一个星期,所以任何帮助都会非常感激!谢谢。 stocks

1 个答案:

答案 0 :(得分:0)

我不明白你在第二个例子中想要做什么,为什么你要将外循环的上下文从股票类别改为股票类别?如果表格映射正确,您所要做的就是遍历内部循环中的第二个关系。

第一个例子就是这样修改,以适应添加表示连接表的实际实体:

<c:forEach var="stock" items="${parentItem.stocks}">
    <div>Stock id: ${stock.id}</div>
    <c:forEach var="stockCategory" items="${stock.stocksCategories}">
        <div style="padding-left:15px">Category id: ${stockCategory.category.id}</div>
    </c:forEach>
</c:forEach>

-

对于三方加入,为什么不这样做呢?

<c:forEach var="stockCategory" items="${parentItem.stocksCategories}">
    <div>Stock id: ${stockCategory.stock.id}</div>
    <div style="padding-left:15px">Category id: ${stockCategory.category.id}</div>
</c:forEach>
相关问题