/* * This is eMonocot, a global online biodiversity information resource. * * Copyright © 2011–2015 The Board of Trustees of the Royal Botanic Gardens, Kew and The University of Oxford * * eMonocot is free software: you can redistribute it and/or modify it under the terms of the * GNU Affero General Public License as published by the Free Software Foundation, either version 3 * of the License, or (at your option) any later version. * * eMonocot is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even * the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * The complete text of the GNU Affero General Public License is in the source repository as the file * ‘COPYING’. It is also available from <http://www.gnu.org/licenses/>. */ package org.emonocot.harvest.common; import java.sql.ResultSet; import java.sql.SQLException; import java.util.HashMap; import java.util.Map; import java.sql.Types; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.jdbc.core.RowMapper; public class RowToMapRowMapper implements RowMapper<Map<String,String>> { private Logger logger = LoggerFactory.getLogger(RowToMapRowMapper.class); @Override public Map<String, String> mapRow(ResultSet resultSet, int rowNumber) throws SQLException { Map<String,String> row = new HashMap<String,String>(); for(int i = 1; i <= resultSet.getMetaData().getColumnCount(); i++) { String columnName = resultSet.getMetaData().getColumnName(i); int type = resultSet.getMetaData().getColumnType(i); switch(type) { case Types.VARCHAR: row.put(columnName, resultSet.getString(columnName)); break; case Types.LONGVARCHAR: row.put(columnName, resultSet.getString(columnName)); break; default: logger.warn("SQL type " + type + " not recognised for column " + i); row.put(columnName, resultSet.getString(columnName)); } } return row; } }