次のコードでネイティブSQLを使用してクエリを作成しています
private <T> List<T> executeNativeQuery(String queryString,
Map<String, Object> param, Class<T> clazz) {
Query query = entityManager.createNativeQuery(queryString);
if (param != null && param.size() > 0) {
for (Map.Entry<String, Object> entry : param.entrySet()) {
query.setParameter(entry.getKey(), entry.getValue());
}
}
List<T> resultList = query.getResultList();
return resultList;
}
そして、次のデータベース結果を取得します。
VendorName | IncidentID | IncidentStatus | IncidentDate
-------------------------------------------------------
XYZ | 100 | Open | 02-JUN-2011
ABC | 101 | Closed | 03-JUN-2011
MNP | 102 | Open | 01-JUN-2011
LPQ | 103 | Open | 01-APR-2011
この結果を繰り返すために、次のアプローチを使用しています
Iterator iter=resultList.iterator();
while (iter.hasNext()) {
Object[] result= (Object[]) iter.next();
System.out.println("Vendor Name-->" +result[0]);
}
リストを反復処理するより良い方法はありますか?