Interface JdbcRowSet
- All Superinterfaces:
- AutoCloseable,- Joinable,- ResultSet,- RowSet,- Wrapper
JdbcRowSet must implement.
 1.0 Overview
A wrapper around aResultSet object that makes it possible
 to use the result set as a JavaBeans
 component.  Thus, a JdbcRowSet object can be one of the Beans that
 a tool makes available for composing an application.  Because
 a JdbcRowSet is a connected rowset, that is, it continually
 maintains its connection to a database using a JDBC technology-enabled
 driver, it also effectively makes the driver a JavaBeans component.
 
 Because it is always connected to its database, an instance of
 JdbcRowSet
 can simply take calls invoked on it and in turn call them on its
 ResultSet object. As a consequence, a result set can, for
 example, be a component in a Swing application.
 
 Another advantage of a JdbcRowSet object is that it can be
 used to make a ResultSet object scrollable and updatable.  All
 RowSet objects are by default scrollable and updatable. If
 the driver and database being used do not support scrolling and/or updating
 of result sets, an application can populate a JdbcRowSet object
 with the data of a ResultSet object and then operate on the
 JdbcRowSet object as if it were the ResultSet
 object.
 
2.0 Creating a JdbcRowSet Object
 The reference implementation of the JdbcRowSet interface,
 JdbcRowSetImpl, provides an implementation of
 the default constructor.  A new instance is initialized with
 default values, which can be set with new values as needed. A
 new instance is not really functional until its execute
 method is called. In general, this method does the following:
 - establishes a connection with a database
-  creates a PreparedStatementobject and sets any of its placeholder parameters
-  executes the statement to create a ResultSetobject
execute method is successful, it will set the
 appropriate private JdbcRowSet fields with the following:
 -  a Connectionobject -- the connection between the rowset and the database
-  a PreparedStatementobject -- the query that produces the result set
-  a ResultSetobject -- the result set that the rowset's command produced and that is being made, in effect, a JavaBeans component
execute
 method has not executed successfully, no methods other than
 execute and close may be called on the
 rowset.  All other public methods will throw an exception.
 
 Before calling the execute method, however, the command
 and properties needed for establishing a connection must be set.
 The following code fragment creates a JdbcRowSetImpl object,
 sets the command and connection properties, sets the placeholder parameter,
 and then invokes the method execute.
 
     JdbcRowSetImpl jrs = new JdbcRowSetImpl();
     jrs.setCommand("SELECT * FROM TITLES WHERE TYPE = ?");
     jrs.setURL("jdbc:myDriver:myAttribute");
     jrs.setUsername("cervantes");
     jrs.setPassword("sancho");
     jrs.setString(1, "BIOGRAPHY");
     jrs.execute();
 
 The variable jrs now represents an instance of
 JdbcRowSetImpl that is a thin wrapper around the
 ResultSet object containing all the rows in the
 table TITLES where the type of book is biography.
 At this point, operations called on jrs will
 affect the rows in the result set, which is effectively a JavaBeans
 component.
 
 The implementation of the RowSet method execute in the
 JdbcRowSet reference implementation differs from that in the
 CachedRowSet
 reference implementation to account for the different
 requirements of connected and disconnected RowSet objects.
- Since:
- 1.5
- 
Field SummaryFields declared in interface java.sql.ResultSetCLOSE_CURSORS_AT_COMMIT, CONCUR_READ_ONLY, CONCUR_UPDATABLE, FETCH_FORWARD, FETCH_REVERSE, FETCH_UNKNOWN, HOLD_CURSORS_OVER_COMMIT, TYPE_FORWARD_ONLY, TYPE_SCROLL_INSENSITIVE, TYPE_SCROLL_SENSITIVE
- 
Method SummaryModifier and TypeMethodDescriptionvoidcommit()EachJdbcRowSetcontains aConnectionobject from theResultSetor JDBC properties passed to it's constructors.booleanEachJdbcRowSetcontains aConnectionobject from the originalResultSetor JDBC properties passed to it.Retrieves the first warning reported by calls on thisJdbcRowSetobject.booleanRetrieves abooleanindicating whether rows marked for deletion appear in the set of current rows.voidrollback()EachJdbcRowSetcontains aConnectionobject from the originalResultSetor JDBC properties passed to it.voidEachJdbcRowSetcontains aConnectionobject from the originalResultSetor JDBC properties passed to it.voidsetAutoCommit(boolean autoCommit) EachJdbcRowSetcontains aConnectionobject from the originalResultSetor JDBC properties passed to it.voidsetShowDeleted(boolean b) Sets the propertyshowDeletedto the givenbooleanvalue.Methods declared in interface javax.sql.rowset.JoinablegetMatchColumnIndexes, getMatchColumnNames, setMatchColumn, setMatchColumn, setMatchColumn, setMatchColumn, unsetMatchColumn, unsetMatchColumn, unsetMatchColumn, unsetMatchColumnMethods declared in interface java.sql.ResultSetabsolute, afterLast, beforeFirst, cancelRowUpdates, clearWarnings, close, deleteRow, findColumn, first, getArray, getArray, getAsciiStream, getAsciiStream, getBigDecimal, getBigDecimal, getBigDecimal, getBigDecimal, getBinaryStream, getBinaryStream, getBlob, getBlob, getBoolean, getBoolean, getByte, getByte, getBytes, getBytes, getCharacterStream, getCharacterStream, getClob, getClob, getConcurrency, getCursorName, getDate, getDate, getDate, getDate, getDouble, getDouble, getFetchDirection, getFetchSize, getFloat, getFloat, getHoldability, getInt, getInt, getLong, getLong, getMetaData, getNCharacterStream, getNCharacterStream, getNClob, getNClob, getNString, getNString, getObject, getObject, getObject, getObject, getObject, getObject, getRef, getRef, getRow, getRowId, getRowId, getShort, getShort, getSQLXML, getSQLXML, getStatement, getString, getString, getTime, getTime, getTime, getTime, getTimestamp, getTimestamp, getTimestamp, getTimestamp, getType, getUnicodeStream, getUnicodeStream, getURL, getURL, getWarnings, insertRow, isAfterLast, isBeforeFirst, isClosed, isFirst, isLast, last, moveToCurrentRow, moveToInsertRow, next, previous, refreshRow, relative, rowDeleted, rowInserted, rowUpdated, setFetchDirection, setFetchSize, updateArray, updateArray, updateAsciiStream, updateAsciiStream, updateAsciiStream, updateAsciiStream, updateAsciiStream, updateAsciiStream, updateBigDecimal, updateBigDecimal, updateBinaryStream, updateBinaryStream, updateBinaryStream, updateBinaryStream, updateBinaryStream, updateBinaryStream, updateBlob, updateBlob, updateBlob, updateBlob, updateBlob, updateBlob, updateBoolean, updateBoolean, updateByte, updateByte, updateBytes, updateBytes, updateCharacterStream, updateCharacterStream, updateCharacterStream, updateCharacterStream, updateCharacterStream, updateCharacterStream, updateClob, updateClob, updateClob, updateClob, updateClob, updateClob, updateDate, updateDate, updateDouble, updateDouble, updateFloat, updateFloat, updateInt, updateInt, updateLong, updateLong, updateNCharacterStream, updateNCharacterStream, updateNCharacterStream, updateNCharacterStream, updateNClob, updateNClob, updateNClob, updateNClob, updateNClob, updateNClob, updateNString, updateNString, updateNull, updateNull, updateObject, updateObject, updateObject, updateObject, updateObject, updateObject, updateObject, updateObject, updateRef, updateRef, updateRow, updateRowId, updateRowId, updateShort, updateShort, updateSQLXML, updateSQLXML, updateString, updateString, updateTime, updateTime, updateTimestamp, updateTimestamp, wasNullMethods declared in interface javax.sql.RowSetaddRowSetListener, clearParameters, execute, getCommand, getDataSourceName, getEscapeProcessing, getMaxFieldSize, getMaxRows, getPassword, getQueryTimeout, getTransactionIsolation, getTypeMap, getUrl, getUsername, isReadOnly, removeRowSetListener, setArray, setAsciiStream, setAsciiStream, setAsciiStream, setAsciiStream, setBigDecimal, setBigDecimal, setBinaryStream, setBinaryStream, setBinaryStream, setBinaryStream, setBlob, setBlob, setBlob, setBlob, setBlob, setBlob, setBoolean, setBoolean, setByte, setByte, setBytes, setBytes, setCharacterStream, setCharacterStream, setCharacterStream, setCharacterStream, setClob, setClob, setClob, setClob, setClob, setClob, setCommand, setConcurrency, setDataSourceName, setDate, setDate, setDate, setDate, setDouble, setDouble, setEscapeProcessing, setFloat, setFloat, setInt, setInt, setLong, setLong, setMaxFieldSize, setMaxRows, setNCharacterStream, setNCharacterStream, setNCharacterStream, setNCharacterStream, setNClob, setNClob, setNClob, setNClob, setNClob, setNClob, setNString, setNString, setNull, setNull, setNull, setNull, setObject, setObject, setObject, setObject, setObject, setObject, setPassword, setQueryTimeout, setReadOnly, setRef, setRowId, setRowId, setShort, setShort, setSQLXML, setSQLXML, setString, setString, setTime, setTime, setTime, setTime, setTimestamp, setTimestamp, setTimestamp, setTimestamp, setTransactionIsolation, setType, setTypeMap, setUrl, setURL, setUsernameMethods declared in interface java.sql.WrapperisWrapperFor, unwrap
- 
Method Details- 
getShowDeletedRetrieves abooleanindicating whether rows marked for deletion appear in the set of current rows. Iftrueis returned, deleted rows are visible with the current rows. Iffalseis returned, rows are not visible with the set of current rows. The default value isfalse.Standard rowset implementations may choose to restrict this behavior for security considerations or for certain deployment scenarios. The visibility of deleted rows is implementation-defined and does not represent standard behavior. Note: Allowing deleted rows to remain visible complicates the behavior of some standard JDBC RowSetimplementations methods. However, most rowset users can simply ignore this extra detail because only very specialized applications will likely want to take advantage of this feature.- Returns:
- trueif deleted rows are visible;- falseotherwise
- Throws:
- SQLException- if a rowset implementation is unable to to determine whether rows marked for deletion remain visible
- See Also:
 
- 
setShowDeletedSets the propertyshowDeletedto the givenbooleanvalue. This property determines whether rows marked for deletion continue to appear in the set of current rows. If the value is set totrue, deleted rows are immediately visible with the set of current rows. If the value is set tofalse, the deleted rows are set as invisible with the current set of rows.Standard rowset implementations may choose to restrict this behavior for security considerations or for certain deployment scenarios. This is left as implementation-defined and does not represent standard behavior. - Parameters:
- b-- trueif deleted rows should be shown;- falseotherwise
- Throws:
- SQLException- if a rowset implementation is unable to to reset whether deleted rows should be visible
- See Also:
 
- 
getRowSetWarningsRetrieves the first warning reported by calls on thisJdbcRowSetobject. If a second warning was reported on thisJdbcRowSetobject, it will be chained to the first warning and can be retrieved by calling the methodRowSetWarning.getNextWarningon the first warning. Subsequent warnings on thisJdbcRowSetobject will be chained to theRowSetWarningobjects returned by the methodRowSetWarning.getNextWarning. The warning chain is automatically cleared each time a new row is read. This method may not be called on aRowSetobject that has been closed; doing so will cause anSQLExceptionto be thrown.Because it is always connected to its data source, a JdbcRowSetobject can rely on the presence of activeStatement,Connection, andResultSetinstances. This means that applications can obtain additionalSQLWarningnotifications by calling thegetNextWarningmethods that they provide. DisconnectedRowsetobjects, such as aCachedRowSetobject, do not have access to thesegetNextWarningmethods.- Returns:
- the first RowSetWarningobject reported on thisJdbcRowSetobject ornullif there are none
- Throws:
- SQLException- if this method is called on a closed- JdbcRowSetobject
- See Also:
 
- 
commitEachJdbcRowSetcontains aConnectionobject from theResultSetor JDBC properties passed to it's constructors. This method wraps theConnectioncommit method to allow flexible auto commit or non auto commit transactional control support.Makes all changes made since the previous commit/rollback permanent and releases any database locks currently held by this Connection object. This method should be used only when auto-commit mode has been disabled. - Throws:
- SQLException- if a database access error occurs or this Connection object within this- JdbcRowSetis in auto-commit mode
- See Also:
 
- 
getAutoCommitEachJdbcRowSetcontains aConnectionobject from the originalResultSetor JDBC properties passed to it. This method wraps theConnection'sgetAutoCommitmethod to allow an application to determine theJdbcRowSettransaction behavior.Sets this connection's auto-commit mode to the given state. If a connection is in auto-commit mode, then all its SQL statements will be executed and committed as individual transactions. Otherwise, its SQL statements are grouped into transactions that are terminated by a call to either the method commit or the method rollback. By default, new connections are in auto-commit mode. - Returns:
- trueif auto-commit is enabled;- falseotherwise
- Throws:
- SQLException- if a database access error occurs
- See Also:
 
- 
setAutoCommitEachJdbcRowSetcontains aConnectionobject from the originalResultSetor JDBC properties passed to it. This method wraps theConnection'sgetAutoCommitmethod to allow an application to set theJdbcRowSettransaction behavior.Sets the current auto-commit mode for this Connectionobject.- Parameters:
- autoCommit-- trueto enable auto-commit;- falseto disable auto-commit
- Throws:
- SQLException- if a database access error occurs
- See Also:
 
- 
rollbackEachJdbcRowSetcontains aConnectionobject from the originalResultSetor JDBC properties passed to it. Undoes all changes made in the current transaction and releases any database locks currently held by thisConnectionobject. This method should be used only when auto-commit mode has been disabled.- Throws:
- SQLException- if a database access error occurs or this- Connectionobject within this- JdbcRowSetis in auto-commit mode.
- See Also:
 
- 
rollbackEachJdbcRowSetcontains aConnectionobject from the originalResultSetor JDBC properties passed to it. Undoes all changes made in the current transaction to the last set savepoint and releases any database locks currently held by thisConnectionobject. This method should be used only when auto-commit mode has been disabled.- Parameters:
- s- The- Savepointto rollback to
- Throws:
- SQLException- if a database access error occurs or this- Connectionobject within this- JdbcRowSetis in auto-commit mode.
- See Also:
 
 
-