我在使用@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中以这种方式显示呢?恢复数据库结构的整个想法感觉不对。
我无法查询库存集合并单独存储它,我必须将它连接到父对象。
我一直在争夺这个约一个星期,所以任何帮助都会非常感激!谢谢。
答案 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>