JSTL を使用して JSP ビューに表示する前に、次のデータ構造を使用して JDBC の結果をサーブレット コントローラーに格納しています。
TreeMap
- TreeMap
- String[]
行ごとに 4 列のデータが返されます。
"CATEGORY","OSDIRECTORY","FILENAME","DESCRIPTION"
"CATEGORY","OSDIRECTORY","FILENAME","DESCRIPTION"
"CATEGORY","OSDIRECTORY","FILENAME","DESCRIPTION"
etc.
目標は、結果を次のようにデータ構造に格納することです。
Category
- FILENAME
- OSDIRECTORY
- DESCRIPTION
そして、ビューに最終結果を次のように表示するには
Category A
Hyperlink
Hyperlink
Hyperlink
Category B
Hyperlink
Hyperlink
etc.
関連するサーブレット コントローラーのコード スニペット
...
TreeMap treeMap = new TreeMap();
rs = stmt.executeQuery(query);
// Gather raw data
while(rs.next()){
if(!treeMap.containsKey(rs.getString("CATEGORY"))){
treeMap.put(rs.getString("CATEGORY"), new TreeMap());
}
String[] tmp = { rs.getString("OSDIRECTORY"), rs.getString("DESCRIPTION") };
((TreeMap)treeMap.get(rs.getString("CATEGORY"))).put(rs.getString("FILENAME"), tmp);
}
request.setAttribute("filemap", treeMap);
RequestDispatcher rd = request.getRequestDispatcher(VIEW_URL);
rd.forward(request, response);
...
関連する JSP ビュー JSTL スニペット
<c:forEach var="f" items="${filemap}">
<h1><c:out value="${f.key}"/></h1>
<c:forEach var="g" items="${filemap[f.key]}">
<a href="TBD">
<c:out value="${filemap[f.key][g.key][0]}"/>
<c:out value="${filemap[f.key][g.key][1]}"/>
</a>
</c:forEach>
</c:forEach>
JSTL 式のいくつかを表現するためのより簡潔な方法があるのではないかと思っています。
たとえば、 ${filemap[f.key][g.key][0]} は冗長すぎるようです。