You are viewing a plain text version of this content. The canonical link for it is here.
Posted to jira@arrow.apache.org by "Jonathan Swenson (Jira)" <ji...@apache.org> on 2022/03/26 00:56:00 UTC
[jira] [Created] (ARROW-16035) [Java] Arrow to JDBC ArrowVectorIterator with does not terminate with empty result set
Jonathan Swenson created ARROW-16035:
----------------------------------------
Summary: [Java] Arrow to JDBC ArrowVectorIterator with does not terminate with empty result set
Key: ARROW-16035
URL: https://issues.apache.org/jira/browse/ARROW-16035
Project: Apache Arrow
Issue Type: Bug
Components: Java
Affects Versions: 7.0.0
Reporter: Jonathan Swenson
Using an ArrowVectorIterator built from a JDBC Result Set that is empty causes the iterator to never terminate.
{code:java}
ArrowVectorIterator iterator =
JdbcToArrow.sqlToArrowVectorIterator(conn.createStatement()
.executeQuery("select 1 from table1 where false"), config); {code}
It appears as though this is due to the implementation of the [hasNext()|https://github.com/apache/arrow/blob/master/java/adapter/jdbc/src/main/java/org/apache/arrow/adapter/jdbc/ArrowVectorIterator.java#L158] method.
The expectation is that the `isAfterLast()` method on a JDBC result set return true when the result set is empty. However, according to the [JDBC documentation|https://docs.oracle.com/en/java/javase/11/docs/api/java.sql/java/sql/ResultSet.html#isAfterLast()] it will always return false when the result set is empty.
{quote}Returns:{{{}true{}}} if the cursor is after the last row; {{false}} if the cursor is at any other position or the result set contains no rows
{quote}
--
This message was sent by Atlassian Jira
(v8.20.1#820001)