/* * Copyright 2004-2014 H2 Group. Multiple-Licensed under the MPL 2.0, * and the EPL 1.0 (http://h2database.com/html/license.html). * Initial Developer: H2 Group */ package org.h2.index; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import org.h2.engine.Session; import org.h2.message.DbException; import org.h2.result.Row; import org.h2.result.SearchRow; import org.h2.value.DataType; import org.h2.value.Value; /** * A cursor for a function that returns a JDBC result set. */ public class FunctionCursorResultSet implements Cursor { private final Session session; private final ResultSet result; private final ResultSetMetaData meta; private Value[] values; private Row row; FunctionCursorResultSet(Session session, ResultSet result) { this.session = session; this.result = result; try { this.meta = result.getMetaData(); } catch (SQLException e) { throw DbException.convert(e); } } @Override public Row get() { if (values == null) { return null; } if (row == null) { row = session.createRow(values, 1); } return row; } @Override public SearchRow getSearchRow() { return get(); } @Override public boolean next() { row = null; try { if (result != null && result.next()) { int columnCount = meta.getColumnCount(); values = new Value[columnCount]; for (int i = 0; i < columnCount; i++) { int type = DataType.getValueTypeFromResultSet(meta, i + 1); values[i] = DataType.readValue(session, result, i + 1, type); } } else { values = null; } } catch (SQLException e) { throw DbException.convert(e); } return values != null; } @Override public boolean previous() { throw DbException.throwInternalError(toString()); } }