Processing Data in a Result Set
Setting a Result Set Type
Different types of result sets apply to different application scenarios. Applications select proper types of result sets based on requirements. Before running an SQL statement, you must create a statement object. Some methods of creating statement objects can set the type of a result set. Table 1 lists result set parameters. The related Connection methods are as follows:
| 1 2 3 4 5 6 7 8 | // Create a Statement object. This object will generate a ResultSet object with a specified type and concurrency. createStatement(int resultSetType, int resultSetConcurrency); // Create a PreparedStatement object. This object will generate a ResultSet object with a specified type and concurrency. prepareStatement(String sql, int resultSetType, int resultSetConcurrency); // Create a CallableStatement object. This object will generate a ResultSet object with a specified type and concurrency. prepareCall(String sql, int resultSetType, int resultSetConcurrency); | 
| Parameter | Description | 
|---|---|
| resultSetType | Type of a result set. There are three types of result sets: 
 
         NOTE: 
         After a result set has obtained data from the database, the result set is insensitive to data changes made by other transactions, even if the result set type is ResultSet.TYPE_SCROLL_SENSITIVE. To obtain up-to-date data of the record pointed by the cursor from the database, call the refreshRow() method in a ResultSet object. | 
| resultSetConcurrency | Concurrency type of a result set. There are two types of concurrency. 
 | 
Positioning a Cursor in a Result Set
ResultSet objects include a cursor pointing to the current data row. The cursor is initially positioned before the first row. The next method moves the cursor to the next row from its current position. When a ResultSet object does not have a next row, a call to the next method returns false. Therefore, this method is used in the while loop for result set iteration. However, the JDBC driver provides more cursor positioning methods for scrollable result sets, which allows positioning cursor in the specified row. Table 2 describes these methods.
| Method | Description | 
|---|---|
| next() | Moves cursor to the next row from its current position. | 
| previous() | Moves cursor to the previous row from its current position. | 
| beforeFirst() | Places cursor before the first row. | 
| afterLast() | Places cursor after the last row. | 
| first() | Places cursor to the first row. | 
| last() | Places cursor to the last row. | 
| absolute(int) | Places cursor to a specified row. | 
| relative(int) | Moves the row specified by the parameter forward (that is, the value is 1, which is equivalent to next()) or backward (that is, the value is -1, which is equivalent to previous()). | 
Obtaining the Cursor Position from a Result Set
This cursor positioning method will be used to change the cursor position for a scrollable result set. The JDBC driver provides a method to obtain the cursor position in a result set. Table 3 describes these methods.
| Method | Description | 
|---|---|
| isFirst() | Checks whether it is in the first row. | 
| isLast() | Checks whether it is in the last row. | 
| isBeforeFirst() | Checks whether it is before the first row. | 
| isAfterLast() | Checks whether it is after the last row. | 
| getRow() | Obtains its current row number. | 
Obtaining Data from a Result Set
ResultSet objects provide a variety of methods to obtain data from a result set. Table 4 describes the common methods for obtaining data. If you want to know more about other methods, see JDK official documents.
| Method | Description | 
|---|---|
| int getInt(int columnIndex) | Retrieves the value of the column designated by a column index in the current row as an integer. | 
| int getInt(String columnLabel) | Retrieves the value of the column designated by a column label in the current row as an integer. | 
| String getString(int columnIndex) | Retrieves the value of the column designated by a column index in the current row as a string. | 
| String getString(String columnLabel) | Retrieves the value of the column designated by a column label in the current row as a string. | 
| Date getDate(int columnIndex) | Retrieves the value of the column designated by a column index in the current row as a date. | 
| Date getDate(String columnLabel) | Retrieves the value of the column designated by a column name in the current row as a date. | 
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.See the reply and handling status in My Cloud VOC.
For any further questions, feel free to contact us through the chatbot.
Chatbot 
    