Why is While (rs.next()) statement ending after 1st iteration?

后端 未结 4 1070
花落未央
花落未央 2021-01-20 03:20

I am using a SELECT statement to get data from a table and then insert it into another table. However the line \"stmt.executeQuery(query);\" is inserting the first line fro

相关标签:
4条回答
  • 2021-01-20 03:52

    Statement objects can only do one thing at a time, so when you execute that INSERT, you invalidate the ResultSet which it generated. You'll need to create a second Statement object to perform the INSERT.

    From the Statement documentation: "By default, only one ResultSet object per Statement object can be open at the same time. Therefore, if the reading of one ResultSet object is interleaved with the reading of another, each must have been generated by different Statement objects. All execution methods in the Statement interface implicitly close a statment's current ResultSet object if an open one exists."

    0 讨论(0)
  • 2021-01-20 03:56

    if you use the same statement, it will invalidate the previous result set. You should use a different statement to perform updates/inserts.

    0 讨论(0)
  • 2021-01-20 03:58

    You are re-using the Statement that was used to produce rs on the last line of your loop.

    This will close the ResultSet rs. As stated in the documentation:

    A ResultSet object is automatically closed when the Statement object that generated it is closed, re-executed, or used to retrieve the next result from a sequence of multiple results.

    You need to use a second Statement object to execute the INSERT statements.

    0 讨论(0)
  • 2021-01-20 04:07

    This is from the Java docs of interface Statement:

    By default, only one ResultSet object per Statement object can be open at the same time.

    So you better use a second Statement or even better a PreparedStatement.

    And to execute an INSERT SQL statement you should use executeUpdate() instead of executeQuery().

    0 讨论(0)
提交回复
热议问题