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

血红的双手。 提交于 2019-12-01 18:22:26
Joachim Sauer

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.

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."

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

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().

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!