Как сопоставить ResultSet с неизвестным количеством столбцов в List и отобразить его в таблице HTML?

Я создал приложение базы данных, используя Netbeans, GlassFish и JavaDB. Теперь мой код сервлета контроллера выполняет некоторые динамические запросы SQL и возвращает набор результатов (или я могу изменить toString). Теперь, как я могу показать возвращенный набор результатов в табличном формате (я понятия не имею о структуре набора результатов). Кто-нибудь может мне помочь по этому поводу?

2 ответа

Решение

Ты можешь использовать Map<String, Object> представлять "динамическую" строку, которая повторяется в <c:forEach>, Ты можешь использовать ResultSetMetaData собирать информацию о столбцах, такую ​​как количество столбцов и метки столбцов.

Итак, это отображение должно сделать:

List<Map<String, Object>> rows = new ArrayList<Map<String, Object>>();
ResultSetMetaData metaData = resultSet.getMetaData();
int columnCount = metaData.getColumnCount();

while (resultSet.next()) {
    Map<String, Object> columns = new LinkedHashMap<String, Object>();

    for (int i = 1; i <= columnCount; i++) {
        columns.put(metaData.getColumnLabel(i), resultSet.getObject(i));
    }

    rows.add(columns);
}

Вы можете отобразить его в JSP следующим образом:

<table>
  <thead>
    <tr>
      <c:forEach items="${rows[0]}" var="column">
        <td><c:out value="${column.key}" /></td>
      </c:forEach>
    </tr>
  </thead>
  <tbody>
    <c:forEach items="${rows}" var="columns">
      <tr>
        <c:forEach items="${columns}" var="column">
          <td><c:out value="${column.value}" /></td>
        </c:forEach>
      </tr>
    </c:forEach>
  </tbody>
</table>

Используйте метаданные набора результатов, чтобы узнать количество столбцов, возвращаемых запросом, тип этих столбцов и т. Д.

Смотрите Javadoc, который также имеет пример.

Другие вопросы по тегам