Class EnhancedPreparedStatementBase
- All Implemented Interfaces:
AutoCloseable
,EnhancedPreparedStatement
- Direct Known Subclasses:
EnhancedPreparedStatementImpl
EnhancedPreparedStatement
.- Author:
- Thomas Thrien (thomas.thrien@tquadrat.org)
- Version:
- $Id: EnhancedPreparedStatementBase.java 1100 2024-02-16 23:33:45Z tquadrat $
- Since:
- 0.1.0
- UML Diagram
-
UML Diagram for "org.tquadrat.foundation.sql.internal.EnhancedPreparedStatementBase"
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprotected final class
The base class for a variant ofParameterMetaData
that is used byEnhancedPreparedStatement
.Nested classes/interfaces inherited from interface org.tquadrat.foundation.sql.EnhancedPreparedStatement
EnhancedPreparedStatement.StatementLogger
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate int
The counter for the added batch commands.The parameter index.private final PreparedStatement
The wrappedPreparedStatement
.private final String
The statement source.private final LazyMap
<String, StatementValue> The values.Fields inherited from interface org.tquadrat.foundation.sql.EnhancedPreparedStatement
VARIABLE_PATTERN
-
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
EnhancedPreparedStatementBase
(String sourceStatement, PreparedStatement preparedStatement, Map<String, int[]> parameterIndex) Creates a new instance ofEnhancedPreparedStatementBase
. -
Method Summary
Modifier and TypeMethodDescriptionfinal void
addBatch()
Adds a set of parameters to thisEnhancedPreparedStatement
instance's batch of commands.protected abstract boolean
Returns a flag that indicates whether a stacktrace should be added to the logging.final void
cancel()
Cancels thisEnhancedPreparedStatement
object if both the DBMS and driver support aborting an SQL statement.final void
Empties thisEnhancedPreparedStatement
instance's current list of SQL commands.void
Clears the current parameter values immediately.final void
Clears all the warnings reported on thisEnhancedPreparedStatement
instance.final void
close()
Releases this instance's database and JDBC resources immediately instead of waiting for this to happen when it is automatically closed.final void
Specifies that thisEnhancedPreparedStatement
will be closed when all its dependent result sets are closed.protected abstract void
doLogging
(String operation, StackTraceElement[] stackTrace) Composes the log information and sends it.final String
enquoteIdentifier
(String identifier, boolean alwaysQuote) Returns a SQL identifier.final String
enquoteLiteral
(String value) Returns aString
enclosed in single quotes.final String
Returns aString
representing a National Character Set Literal enclosed in single quotes and prefixed with a upper case letterN
.final boolean
execute()
Executes the SQL statement in thisPreparedStatement
object, which may be any kind of SQL statement.final int[]
Submits a batch of commands to the database for execution and if all commands execute successfully, returns an array of update counts.long[]
Submits a batch of commands to the database for execution and if all commands execute successfully, returns an array of update counts.final long
Executes the SQL statement in thisEnhancedPreparedStatement
instance.final ResultSet
Executes the SQL query in thisPreparedStatement
object and returns theResultSet
object generated by the query.final int
Executes the SQL statement in thisEnhancedPreparedStatement
instance.final Connection
Retrieves theConnection
instance that produced thePreparedStatement
instance wrapped by thisEnhancedPreparedStatement
.protected final Collection
<StatementValue> Provides the current values for logging purposes.final int
Retrieves the direction for fetching rows from database tables that is the default for result sets generated from thisEnhancedPreparedStatement
instance.final int
Retrieves the number of result set rows that is the default fetch size forResultSet
instances generated from thisEnhancedPreparedStatement
instance.final ResultSet
Retrieves any auto-generated keys created as a result of executing thisEnhancedPreparedStatement
instance.final long
Retrieves the maximum number of rows that aResultSet
instance produced by thisEnhancedPreparedStatement
instance can contain.final long
Retrieves the current result as an update count.final int
Retrieves the maximum number of bytes that can be returned for character and binary column values in aResultSet
object produced by thisEnhancedPreparedStatement
object.final int
Retrieves the maximum number of rows that aResultSet
instance produced by thisEnhancedPreparedStatement
instance can contain.final ResultSetMetaData
Retrieves aResultSetMetaData
object that contains information about the columns of theResultSet
instance that will be returned when thisEnhancedPreparedStatement
instance is executed.final boolean
Moves to thisEnhancedPreparedStatement
instance's next result, returnstrue
if it is aResultSet
instance, and implicitly closes any currentResultSet
instance(s) previously obtained with the methodEnhancedPreparedStatement.getResultSet()
.final boolean
getMoreResults
(int current) Moves to thisEnhancedPreparedStatement
instance's next result, deals with any currentResultSet
instance(s) according to the instructions specified by the given flag, and returnstrue
if the next result is aResultSet
object.protected final int[]
getParameterIndexes
(String parameterName) Returns the parameter indexes for the given parameter name.Retrieves the number, types and properties of thisEnhancedPreparedStatement
instance's parameters.protected final Collection
<String> Returns the parameter names for thisEnhancedPreparedStatement
.final int
Retrieves the number of seconds the driver will wait for aStatement
instance to execute.final ResultSet
Retrieves the current result as aResultSet
instance.final int
Retrieves the result set concurrency forResultSet
instances generated by thisEnhancedPreparedStatement
instance.final int
Retrieves the result set holdability forResultSet
instances generated by thisEnhancedPreparedStatement
instance.final int
Retrieves the result set type forResultSet
instances generated by thisEnhancedPreparedStatement
instance.protected final String
Provides the source statement for logging purposes.final int
Retrieves the current result as an update count.final SQLWarning
Retrieves the first warning reported by calls on thisEnhancedPreparedStatement
instance.final boolean
isClosed()
Retrieves whether thisEnhancedPreparedStatement
object has been closed.final boolean
Returns a value indicating whether thisEnhancedPreparedStatement
will be closed when all its dependent result sets are closed.abstract boolean
Checks whether logging is currently enabled.final boolean
Returns a value indicating whether the wrappedPreparedStatement
is poolable or not.final boolean
isSimpleIdentifier
(String identifier) Retrieves whetheridentifier
is a simple SQL identifier.final void
Sets the designated parameter to the givenArray
instance.void
setAsciiStream
(String parameterName, InputStream value) Sets the designated parameter to the givenInputStream
.void
setAsciiStream
(String parameterName, InputStream value, int length) Sets the designated parameter to the givenInputStream
which will have the specified number of bytes.void
setAsciiStream
(String parameterName, InputStream value, long length) Sets the designated parameter to the givenInputStream
which will have the specified number of bytes.final void
setBigDecimal
(String parameterName, BigDecimal value) Sets the designated parameter to the given JavaBigDecimal
value.void
setBinaryStream
(String parameterName, InputStream value) Sets the designated parameter to the givenInputStream
.void
setBinaryStream
(String parameterName, InputStream value, int length) Sets the designated parameter to the givenInputStream
which will have the specified number of bytes.void
setBinaryStream
(String parameterName, InputStream value, long length) Sets the designated parameter to the givenInputStream
which will have the specified number of bytes.final void
setBlob
(String parameterName, InputStream value) Sets the designated parameter to aInputStream
object.final void
setBlob
(String parameterName, InputStream value, long length) Sets the designated parameter to aInputStream
object.final void
Sets the designated parameter to the given JavaBlob
instance.final void
setBoolean
(String parameterName, boolean value) Sets the designated parameter to the given Javaboolean
value.final void
Sets the designated parameter to the given Javabyte
value.final void
Sets the designated parameter to the given Java array of bytes.final void
setCharacterStream
(String parameterName, Reader value) Sets the designated parameter to the givenReader
instance.final void
setCharacterStream
(String parameterName, Reader value, int length) Sets the designated parameter to the givenReader
instance, which provides the given number of characters.final void
setCharacterStream
(String parameterName, Reader value, long length) Sets the designated parameter to the givenReader
instance, which provides the given number of characters.final void
Sets the designated parameter to aReader
instance.final void
Sets the designated parameter to aReader
instance.final void
Sets the designated parameter to the givenClob
instance.final void
setCursorName
(String name) Sets the SQL cursor name to the given String, which will be used by subsequent statementexecute()
methods.final void
Sets the designated parameter to the givenDate
value using the default time zone of the virtual machine that is running the application.void
final void
Sets the designated parameter to the given Javadouble
value.final void
setFetchDirection
(int direction) Gives the driver a hint as to the direction in which rows will be processed inResultSet
instances created using thisEnhancedPreparedStatement
object.final void
setFetchSize
(int rows) Gives the JDBC driver a hint as to the number of rows that should be fetched from the database when more rows are needed forResultSet
instances generated by thisEnhancedPreparedStatement
instance.final void
Sets the designated parameter to the given Javafloat
value.final void
Sets the designated parameter to the given Javaint
value.final void
setLargeMaxRows
(long max) Sets the limit for the maximum number of rows that anyResultSet
instance generated by thisEnhancedPreparedStatement
instance can contain.final void
Sets the designated parameter to the given Javalong
value.final void
setMaxFieldSize
(int max) Sets the limit for the maximum number of bytes that can be returned for character and binary column values in aResultSet
object produced by thisStatement
object.final void
setMaxRows
(int max) Sets the limit for the maximum number of rows, that anyResultSet
instance generated by thisEnhancedPreparedStatement
instance can contain, to the given number.final void
setNCharacterStream
(String parameterName, Reader value) Sets the designated parameter to the givenReader
instance.final void
setNCharacterStream
(String parameterName, Reader value, long length) Sets the designated parameter to the givenReader
instance.final void
Sets the designated parameter to aReader
instance.final void
Sets the designated parameter to aReader
instance.final void
Sets the designated parameter to the givenNClob
value.final void
setNString
(String parameterName, String value) Sets the designated parameter to the given JavaString
value.final void
Sets the designated parameter to SQLNULL
.void
Sets the designated parameter to SQLNULL
.final void
Sets the value of the designated parameter using the given object.void
Sets the value of the designated parameter with the given object.final void
Sets the value of the designated parameter using the given object.final void
setQueryTimeout
(int timeout) Sets the number of seconds the driver will wait for aStatement
instance to execute to the given number of seconds.final void
Sets the designated parameter to the givenREF(<structured-type>)
value.final void
Sets the designated parameter to the givenRowId
instance.final void
Sets the designated parameter to the given Javashort
value.final void
Sets the designated parameter to the givenSQLXML
value.final void
Sets the designated parameter to the given JavaString
value.final void
Sets the designated parameter to the givenTime
value.final void
final void
setTimestamp
(String parameterName, Timestamp value) Sets the designated parameter to the givenTimestamp
value.final void
setTimestamp
(String parameterName, Timestamp value, Calendar calendar) final void
Sets the designated parameter to the givenURL
value.
-
Field Details
-
m_BatchCounter
The counter for the added batch commands. -
m_ParameterIndex
The parameter index.
The parameter names are the keys for the map, the values are the indexes.
-
m_PreparedStatement
The wrappedPreparedStatement
. -
m_SourceStatement
The statement source. -
m_Values
The values.
-
-
Constructor Details
-
EnhancedPreparedStatementBase
protected EnhancedPreparedStatementBase(String sourceStatement, PreparedStatement preparedStatement, Map<String, int[]> parameterIndex) Creates a new instance ofEnhancedPreparedStatementBase
.- Parameters:
sourceStatement
- The original SQL statement with the placeholders; mainly used for logging purposes.preparedStatement
- The wrapped instance ofPreparedStatement
.parameterIndex
- The mapping for the named placeholders to the position based placeholders.
-
-
Method Details
-
addBatch
Adds a set of parameters to thisEnhancedPreparedStatement
instance's batch of commands.- Specified by:
addBatch
in interfaceEnhancedPreparedStatement
- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
addStacktrace
Returns a flag that indicates whether a stacktrace should be added to the logging.- Returns:
true
if the stacktrace should be created and added,false
otherwise.
-
cancel
Cancels this
EnhancedPreparedStatement
object if both the DBMS and driver support aborting an SQL statement.This method can be used by one thread to cancel a statement that is being executed by another thread.
- Specified by:
cancel
in interfaceEnhancedPreparedStatement
- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
clearBatch
Empties thisEnhancedPreparedStatement
instance's current list of SQL commands.- Specified by:
clearBatch
in interfaceEnhancedPreparedStatement
- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
, or the driver does not support batch updates.- See Also:
-
clearParameters
Clears the current parameter values immediately.
In general, parameter values remain in force for repeated use of a statement. Setting a parameter value automatically clears its previous value. However, in some cases it is useful to immediately release the resources used by the current parameter values; this can be done by calling the method
clearParameters()
.- Specified by:
clearParameters
in interfaceEnhancedPreparedStatement
- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
clearWarnings
Clears all the warnings reported on this
EnhancedPreparedStatement
instance. After a call to this method, the methodEnhancedPreparedStatement.getWarnings()
will returnnull
until a new warning is reported for thisEnhancedPreparedStatement
instance.- Specified by:
clearWarnings
in interfaceEnhancedPreparedStatement
- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
close
Releases this instance's database and JDBC resources immediately instead of waiting for this to happen when it is automatically closed. It is generally good practice to release resources as soon as you are finished with them to avoid tying up database resources.
Calling the method
close
on aEnhancedPreparedStatement
object that is already closed has no effect.- Specified by:
close
in interfaceAutoCloseable
- Specified by:
close
in interfaceEnhancedPreparedStatement
- Throws:
SQLException
- A database access error occurred.
-
closeOnCompletion
Description copied from interface:EnhancedPreparedStatement
Specifies that this
EnhancedPreparedStatement
will be closed when all its dependent result sets are closed. If the execution of theEnhancedPreparedStatement
does not produce any result sets, this method has no effect.- Specified by:
closeOnCompletion
in interfaceEnhancedPreparedStatement
- Throws:
SQLException
- This method was called on a closedEnhancedPreparedStatement
.
-
doLogging
Composes the log information and sends it.- Parameters:
operation
- The operation that logs.stackTrace
- The stack trace; can benull
.
-
enquoteIdentifier
Returns a SQL identifier. If
identifier
is a simple SQL identifier:- Return the original value if
alwaysQuote
isfalse
- Return a delimited identifier if
alwaysQuote
istrue
If
identifier
is not a simple SQL identifier,identifier
will be enclosed in double quotes if not already present. If the datasource does not support double quotes for delimited identifiers, the identifier should be enclosed by the string returned fromDatabaseMetaData.getIdentifierQuoteString()
. If the datasource does not support delimited identifiers, aSQLFeatureNotSupportedException
should be thrown.A
SQLException
will be thrown ifidentifier
contains any characters invalid in a delimited identifier or the identifier length is invalid for the datasource.- Specified by:
enquoteIdentifier
in interfaceEnhancedPreparedStatement
- Parameters:
identifier
- An SQL identifier.alwaysQuote
- Indicates if a simple SQL identifier should be returned as a quoted identifier.- Returns:
- A simple SQL identifier or a delimited identifier
- Throws:
SQLException
- The identifier was not a valid identifier.
- Return the original value if
-
enquoteLiteral
Returns a
String
enclosed in single quotes. Any occurrence of a single quote within the string will be replaced by two single quotes.Examples of the conversion: Value Result Hello 'Hello' G'Day 'G''Day' 'G''Day' '''G''''Day''' I'''M 'I''''''M' - Specified by:
enquoteLiteral
in interfaceEnhancedPreparedStatement
- Parameters:
value
- A character String.- Returns:
- A string enclosed by single quotes with every single quote converted to two single quotes
- Throws:
SQLException
- A database access error occurred.
-
enquoteNCharLiteral
Returns a
String
representing a National Character Set Literal enclosed in single quotes and prefixed with a upper case letterN
. Any occurrence of a single quote within the string will be replaced by two single quotes.Examples of the conversion: Value Result Hello N'Hello' G'Day N'G''Day' 'G''Day' N'''G''''Day''' I'''M N'I''''''M' N'Hello' N'N''Hello''' - Specified by:
enquoteNCharLiteral
in interfaceEnhancedPreparedStatement
- Parameters:
s
- A character string- Returns:
- The result of replacing every single quote character in the argument by two single quote characters where this entire result is then prefixed with 'N'.
- Throws:
SQLException
- A database access error occurred.- See Also:
-
execute
Executes the SQL statement in this
PreparedStatement
object, which may be any kind of SQL statement.Some prepared statements return multiple results; the
execute()
method handles these complex statements as well as the simpler form of statements handled by the methodsEnhancedPreparedStatement.executeQuery()
andEnhancedPreparedStatement.executeUpdate()
.The
execute()
method returns aboolean
to indicate the form of the first result. You must call either the methodEnhancedPreparedStatement.getResultSet()
orEnhancedPreparedStatement.getUpdateCount()
to retrieve the result; you must callEnhancedPreparedStatement.getMoreResults()
to move to any subsequent result(s).- Specified by:
execute
in interfaceEnhancedPreparedStatement
- Returns:
true
if the first result is aResultSet
instance;false
if the first result is an update count or there is no result.- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or no argument was supplied for at least one parameter.- See Also:
-
executeBatch
Submits a batch of commands to the database for execution and if all commands execute successfully, returns an array of update counts. The
int
elements of the array that is returned are ordered to correspond to the commands in the batch, which are ordered according to the order in which they were added to the batch.The elements in the array returned by the method
executeBatch()
may be one of the following:- A number greater than or equal to zero – indicates that the command was processed successfully and is an update count giving the number of rows in the database that were affected by the command's execution.
- A value of
Statement.SUCCESS_NO_INFO
(-2 – indicates that the command was processed successfully but that the number of rows affected is unknown.
If one of the commands in a batch update fails to execute properly, this method throws a
BatchUpdateException
, and a JDBC driver may or may not continue to process the remaining commands in the batch. However, the driver's behaviour must be consistent with a particular DBMS, either always continuing to process commands or never continuing to process commands. If the driver continues processing after a failure, the array returned by the methodBatchUpdateException.getUpdateCounts()
will contain as many elements as there are commands in the batch, and at least one of the elements will beStatement.EXECUTE_FAILED
(-3 – indicating that the command failed to execute successfully); it occurs only if a driver continues to process commands after a command failed.- Specified by:
executeBatch
in interfaceEnhancedPreparedStatement
- Returns:
- An array of update counts containing one element for each command in the batch. The elements of the array are ordered according to the order in which commands were added to the batch.
- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the driver does not support batch statements.- See Also:
-
executeLargeBatch
Description copied from interface:EnhancedPreparedStatement
Submits a batch of commands to the database for execution and if all commands execute successfully, returns an array of update counts. The
int
elements of the array that is returned are ordered to correspond to the commands in the batch, which are ordered according to the order in which they were added to the batch.The elements in the array returned by the method
executeBatch()
may be one of the following:- A number greater than or equal to zero – indicates that the command was processed successfully and is an update count giving the number of rows in the database that were affected by the command's execution.
- A value of
Statement.SUCCESS_NO_INFO
(-2 – indicates that the command was processed successfully but that the number of rows affected is unknown.
If one of the commands in a batch update fails to execute properly, this method throws a
BatchUpdateException
, and a JDBC driver may or may not continue to process the remaining commands in the batch. However, the driver's behaviour must be consistent with a particular DBMS, either always continuing to process commands or never continuing to process commands. If the driver continues processing after a failure, the array returned by the methodBatchUpdateException.getLargeUpdateCounts()
will contain as many elements as there are commands in the batch, and at least one of the elements will beStatement.EXECUTE_FAILED
(-3 – indicating that the command failed to execute successfully); it occurs only if a driver continues to process commands after a command failed.This method should be used when the returned row count may exceed
Integer.MAX_VALUE
.- Specified by:
executeLargeBatch
in interfaceEnhancedPreparedStatement
- Returns:
- An array of update counts containing one element for each command in the batch. The elements of the array are ordered according to the order in which commands were added to the batch.
- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the driver does not support batch statements.- See Also:
-
executeLargeUpdate
Executes the SQL statement in this
EnhancedPreparedStatement
instance. It must be an SQL Data Manipulation Language (DML) statement, such asINSERT
,UPDATE
orDELETE
; or an SQL statement that returns nothing, such as a DDL statement.This method should be used when the returned row count may exceed
Integer.MAX_VALUE
.The default implementation will throw
UnsupportedOperationException
.- Specified by:
executeLargeUpdate
in interfaceEnhancedPreparedStatement
- Returns:
- Either the row count for SQL Data Manipulation Language (DML) statements or 0 for SQL statements that return nothing.
- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the SQL statement returns aResultSet
object.
-
executeQuery
Executes the SQL query in this
PreparedStatement
object and returns theResultSet
object generated by the query.- Specified by:
executeQuery
in interfaceEnhancedPreparedStatement
- Returns:
- A
ResultSet
instance that contains the data produced by the query; nevernull
. - Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the SQL statement did not return aResultSet
object.
-
executeUpdate
Executes the SQL statement in this
EnhancedPreparedStatement
instance. It must be an SQL Data Manipulation Language (DML) statement, such asINSERT
,UPDATE
orDELETE
; or an SQL statement that returns nothing, such as a DDL statement.- Specified by:
executeUpdate
in interfaceEnhancedPreparedStatement
- Returns:
- Either the row count for SQL Data Manipulation Language (DML) statements or 0 for SQL statements that return nothing.
- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the SQL statement returns aResultSet
object.
-
getCurrentValues
Provides the current values for logging purposes.- Returns:
- The current values.
-
getConnection
Retrieves the
Connection
instance that produced thePreparedStatement
instance wrapped by thisEnhancedPreparedStatement
.- Specified by:
getConnection
in interfaceEnhancedPreparedStatement
- Returns:
- The connection that produced the wrapped prepared statement.
- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
getFetchDirection
Retrieves the direction for fetching rows from database tables that is the default for result sets generated from this
EnhancedPreparedStatement
instance.If this
EnhancedPreparedStatement
instance has not set a fetch direction by calling the methodEnhancedPreparedStatement.setFetchDirection(int)
, the return value is implementation-specific.- Specified by:
getFetchDirection
in interfaceEnhancedPreparedStatement
- Returns:
- The default fetch direction for result sets generated from this
EnhancedPreparedStatement
instance. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getFetchSize
Retrieves the number of result set rows that is the default fetch size for
ResultSet
instances generated from thisEnhancedPreparedStatement
instance. If this statement instance has not set a fetch size by calling the methodEnhancedPreparedStatement.setFetchSize(int)
, the return value is implementation-specific.- Specified by:
getFetchSize
in interfaceEnhancedPreparedStatement
- Returns:
- The default fetch size for result sets generated from this
EnhancedPreparedStatement
instance. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getGeneratedKeys
Retrieves any auto-generated keys created as a result of executing this
EnhancedPreparedStatement
instance. If this statement did not generate any keys, an emptyResultSet
object is returned.- Specified by:
getGeneratedKeys
in interfaceEnhancedPreparedStatement
- Returns:
- A
ResultSet
instance containing the auto-generated key(s) generated by the execution of thisEnhancedPreparedStatement
instance. - Throws:
SQLException
- A database access error occurred or this method was called on a closedStatement
.
-
getLargeMaxRows
Retrieves the maximum number of rows that a
ResultSet
instance produced by thisEnhancedPreparedStatement
instance can contain. If this limit is exceeded, the excess rows are silently dropped.This method should be used when the returned row limit may exceed
Integer.MAX_VALUE
.The default implementation will return
0
.- Specified by:
getLargeMaxRows
in interfaceEnhancedPreparedStatement
- Returns:
- The current maximum number of rows for a
ResultSet
instance produced by thisEnhancedPreparedStatement
instance; zero means there is no limit, or that the method is not supported by the JDBC driver. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getLargeUpdateCount
Retrieves the current result as an update count. If the result is a
ResultSet
object or there are no more results, -1 is returned.This method should be used when the returned row count may exceed
Integer.MAX_VALUE
.The default implementation will throw
UnsupportedOperationException
- Specified by:
getLargeUpdateCount
in interfaceEnhancedPreparedStatement
- Returns:
- The current result as an update count; -1 if the current result
is a
ResultSet
object or there are no more results. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getMaxFieldSize
Retrieves the maximum number of bytes that can be returned for character and binary column values in a
ResultSet
object produced by thisEnhancedPreparedStatement
object.This limit applies only to
JDBCType.BINARY
,JDBCType.VARBINARY
,JDBCType.LONGVARBINARY
,JDBCType.CHAR
,JDBCType.VARCHAR
,JDBCType.NCHAR
,JDBCType.NVARCHAR
,JDBCType.LONGNVARCHAR
andJDBCType.LONGVARCHAR
columns. If the limit is exceeded, the excess data is silently discarded.- Specified by:
getMaxFieldSize
in interfaceEnhancedPreparedStatement
- Returns:
- The current column size limit for columns storing character and binary values; zero means there is no limit.
- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
- See Also:
-
getMaxRows
Retrieves the maximum number of rows that a
ResultSet
instance produced by thisEnhancedPreparedStatement
instance can contain. If this limit is exceeded, the excess rows are silently dropped.- Specified by:
getMaxRows
in interfaceEnhancedPreparedStatement
- Returns:
- The current maximum number of rows for a
ResultSet
instance produced by thisEnhancedPreparedStatement
instance; zero means there is no limit. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getMetaData
Retrieves a
ResultSetMetaData
object that contains information about the columns of theResultSet
instance that will be returned when thisEnhancedPreparedStatement
instance is executed.Because the
PreparedStatement
that is wrapped by thisEnhancedPreparedStatement
is precompiled, it is possible to know about theResultSet
object that it will return without having to execute it. Consequently, it is possible to invoke the methodgetMetaData()
on aEnhancedPreparedStatement
instance rather than waiting to execute it and then invoking theResultSet.getMetaData()
method on theResultSet
instance that is returned.- Specified by:
getMetaData
in interfaceEnhancedPreparedStatement
- Returns:
- The description of a
ResultSet
object's columns ornull
if the driver cannot return aResultSetMetaData
object. - Throws:
SQLException
- A database access error occurred or this method was called on a closedPreparedStatement
.
-
getMoreResults
Moves to this
EnhancedPreparedStatement
instance's next result, returnstrue
if it is aResultSet
instance, and implicitly closes any currentResultSet
instance(s) previously obtained with the methodEnhancedPreparedStatement.getResultSet()
.There are no more results when the following is true:
// stmt is a EnhancedPreparedStatement object ((stmt.getMoreResults() == false) && (stmt.getUpdateCount() == -1))
- Specified by:
getMoreResults
in interfaceEnhancedPreparedStatement
- Returns:
true
if the next result is aResultSet
instance;false
if it is an update count or there are no more results.- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getMoreResults
Moves to this
EnhancedPreparedStatement
instance's next result, deals with any currentResultSet
instance(s) according to the instructions specified by the given flag, and returnstrue
if the next result is aResultSet
object.There are no more results when the following is true:
// stmt is a Statement object ((stmt.getMoreResults( current ) == false) && (stmt.getUpdateCount() == -1))
- Specified by:
getMoreResults
in interfaceEnhancedPreparedStatement
- Parameters:
current
- One of the followingStatement
constants indicating what should happen to currentResultSet
instances obtained using the methodEnhancedPreparedStatement.getResultSet()
:Statement.CLOSE_CURRENT_RESULT
,Statement.KEEP_CURRENT_RESULT
, orStatement.CLOSE_ALL_RESULTS
.- Returns:
true
if the next result is aResultSet
instance,false
if it is an update count or there are no more results- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the argument supplied is not one of the following:Statement.CLOSE_CURRENT_RESULT
,Statement.KEEP_CURRENT_RESULT
, orStatement.CLOSE_ALL_RESULTS
.- See Also:
-
getParameterIndexes
Returns the parameter indexes for the given parameter name.- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.- Returns:
- The parameter indexes for this parameter name.
- Throws:
SQLException
- The given parameter name is not defined.
-
getParameterMetaData
Description copied from interface:EnhancedPreparedStatement
Retrieves the number, types and properties of thisEnhancedPreparedStatement
instance's parameters.- Specified by:
getParameterMetaData
in interfaceEnhancedPreparedStatement
- Returns:
- An instance of
ParameterMetaData
that contains information about the number, types and properties for each named parameter of thisEnhancedPreparedStatement
instance. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getParameterNames
Returns the parameter names for thisEnhancedPreparedStatement
.- Returns:
- The parameter names.
-
getQueryTimeout
Retrieves the number of seconds the driver will wait for a
Statement
instance to execute. If the limit is exceeded, aSQLTimeoutException
is thrown.- Specified by:
getQueryTimeout
in interfaceEnhancedPreparedStatement
- Returns:
- The current query timeout limit in seconds; zero means there is no limit.
- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getResultSet
Retrieves the current result as a
ResultSet
instance.- Specified by:
getResultSet
in interfaceEnhancedPreparedStatement
- Returns:
- The current result as a
ResultSet
instance ornull
if the result is an update count or there are no more results. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getResultSetConcurrency
Retrieves the result set concurrency forResultSet
instances generated by thisEnhancedPreparedStatement
instance.- Specified by:
getResultSetConcurrency
in interfaceEnhancedPreparedStatement
- Returns:
- Either
ResultSet.CONCUR_READ_ONLY
orResultSet.CONCUR_UPDATABLE
. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
getResultSetHoldability
Retrieves the result set holdability forResultSet
instances generated by thisEnhancedPreparedStatement
instance.- Specified by:
getResultSetHoldability
in interfaceEnhancedPreparedStatement
- Returns:
- Either
ResultSet.HOLD_CURSORS_OVER_COMMIT
(1) orResultSet.CLOSE_CURSORS_AT_COMMIT
(2). - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
getResultSetType
Retrieves the result set type forResultSet
instances generated by thisEnhancedPreparedStatement
instance.- Specified by:
getResultSetType
in interfaceEnhancedPreparedStatement
- Returns:
- One of
ResultSet.TYPE_FORWARD_ONLY
,ResultSet.TYPE_SCROLL_INSENSITIVE
, orResultSet.TYPE_SCROLL_SENSITIVE
. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
getSourceStatement
Provides the source statement for logging purposes.- Returns:
- The source statement.
-
getUpdateCount
Retrieves the current result as an update count. If the result is a
ResultSet
object or there are no more results, -1 is returned.- Specified by:
getUpdateCount
in interfaceEnhancedPreparedStatement
- Returns:
- The current result as an update count; -1 if the current result
is a
ResultSet
object or there are no more results. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
getWarnings
Retrieves the first warning reported by calls on this
.EnhancedPreparedStatement
instance. Subsequent warnings regarding the execution of this instance will be chained to thisSQLWarning
instanceThe warning chain is automatically cleared each time a statement is (re)executed. This method may not be called on a closed
EnhancedPreparedStatement
instance; doing so will cause anSQLException
to be thrown.- Specified by:
getWarnings
in interfaceEnhancedPreparedStatement
- Returns:
- The first
SQLWarning
object ornull
if there are no warnings. - Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
isClosed
Retrieves whether this
EnhancedPreparedStatement
object has been closed. AnEnhancedPreparedStatement
is closed if the methodEnhancedPreparedStatement.close()
has been called on it, or if it is automatically closed.- Specified by:
isClosed
in interfaceEnhancedPreparedStatement
- Returns:
true
if thisEnhancedPreparedStatement
object is closed;false
if it is still open.- Throws:
SQLException
- A database access error occurred.
-
isCloseOnCompletion
Returns a value indicating whether this
EnhancedPreparedStatement
will be closed when all its dependent result sets are closed.- Specified by:
isCloseOnCompletion
in interfaceEnhancedPreparedStatement
- Returns:
true
if thisEnhancedPreparedStatement
will be closed when all of its dependent result sets are closed,false
otherwise.- Throws:
SQLException
- This method was called on a closedEnhancedPreparedStatement
.
-
isLoggingEnabled
Checks whether logging is currently enabled.- Specified by:
isLoggingEnabled
in interfaceEnhancedPreparedStatement
- Returns:
true
if logging is enabled and log information have to be collected,false
otherwise.
-
isPoolable
Returns a value indicating whether the wrappedPreparedStatement
is poolable or not.- Specified by:
isPoolable
in interfaceEnhancedPreparedStatement
- Returns:
true
if thePreparedStatement
is poolable,false
otherwise- Throws:
SQLException
- This method was called on a closedEnhancedPreparedStatement
- See Also:
-
isSimpleIdentifier
Retrieves whetheridentifier
is a simple SQL identifier.- Specified by:
isSimpleIdentifier
in interfaceEnhancedPreparedStatement
- Parameters:
identifier
- An SQL identifier- Returns:
true
if the given value is a simple SQL identifier,false
otherwise- Throws:
SQLException
- A database access error occurred.
-
setArray
Sets the designated parameter to the given
Array
instance.The driver converts this to an SQL
ARRAY
value when it sends it to the database.- Specified by:
setArray
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setAsciiStream
Sets the designated parameter to the given
InputStream
which will have the specified number of bytes.When a very large ASCII value is input to a
LONGVARCHAR
parameter, it may be more practical to send it via ajava.io.InputStream
. The data will be read from the stream as needed until end-of-file is reached. The JDBC driver will do any necessary conversion from ASCII to the database char format.- Specified by:
setAsciiStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.length
- The number of bytes in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setAsciiStream
public void setAsciiStream(String parameterName, InputStream value, long length) throws SQLException Sets the designated parameter to the given
InputStream
which will have the specified number of bytes.When a very large ASCII value is input to a
LONGVARCHAR
parameter, it may be more practical to send it via ajava.io.InputStream
. The data will be read from the stream as needed until end-of-file is reached. The JDBC driver will do any necessary conversion from ASCII to the database char format.- Specified by:
setAsciiStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.length
- The number of bytes in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setAsciiStream
Sets the designated parameter to the given
InputStream
.When a very large ASCII value is input to a
LONGVARCHAR
parameter, it may be more practical to send it via ajava.io.InputStream
. The data will be read from the stream as needed until end-of-file is reached. The JDBC driver will do any necessary conversion from ASCII to the database char format.- Specified by:
setAsciiStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setBinaryStream
public void setBinaryStream(String parameterName, InputStream value, int length) throws SQLException Sets the designated parameter to the given
InputStream
which will have the specified number of bytes.When a very large binary value is input to a
LONGVARBINARY
parameter, it may be more practical to send it via ajava.io.InputStream
. The data will be read from the stream as needed until end-of-file is reached.- Specified by:
setBinaryStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.length
- The number of bytes in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setBinaryStream
public void setBinaryStream(String parameterName, InputStream value, long length) throws SQLException Sets the designated parameter to the given
InputStream
which will have the specified number of bytes.When a very large binary value is input to a
LONGVARBINARY
parameter, it may be more practical to send it via ajava.io.InputStream
. The data will be read from the stream as needed until end-of-file is reached.- Specified by:
setBinaryStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.length
- The number of bytes in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setBinaryStream
Sets the designated parameter to the given
InputStream
.When a very large binary value is input to a
LONGVARBINARY
parameter, it may be more practical to send it via ajava.io.InputStream
. The data will be read from the stream as needed until end-of-file is reached.- Specified by:
setBinaryStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setBigDecimal
Sets the designated parameter to the given Java
BigDecimal
value.The driver converts this to an SQL
NUMERIC
value when it sends it to the database.- Specified by:
setBigDecimal
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setBlob
Sets the designated parameter to the given Java
Blob
instance.The driver converts this to an SQL
BLOB
value when it sends it to the database.- Specified by:
setBlob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setBlob
Sets the designated parameter to a
InputStream
object. TheInputStream
must contain the number of characters as specified by thelength
argument, otherwise aSQLException
will be generated when theEnhancedPreparedStatement
is executed.This method differs from the
(String,InputStream,int)
method because it informs the driver that the parameter value should be sent to the server as aBLOB
. When thesetBinaryStream()
method is used, the driver may have to do extra work to determine whether the parameter data should be sent to the server as aLONGVARBINARY
or aBLOB
.- Specified by:
setBlob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- TheInputStream
instance that contains the data to set the parameter value to.length
- The number of bytes in the parameter data.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred, this method was called on a closedEnhancedPreparedStatement
, the specified length was less than zero or if the number of bytes in theInputStream
did not match the specified length.
-
setBlob
Sets the designated parameter to a
InputStream
object.This method differs from the
(String,InputStream,int)
method because it informs the driver that the parameter value should be sent to the server as aBLOB
. When thesetBinaryStream()
method is used, the driver may have to do extra work to determine whether the parameter data should be sent to the server as aLONGVARBINARY
or aBLOB
.- Specified by:
setBlob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- TheInputStream
instance that contains the data to set the parameter value to.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred, or this method was called on a closedEnhancedPreparedStatement
.
-
setBoolean
Sets the designated parameter to the given Java
boolean
value.The driver converts this to an SQL
BIT
orBOOLEAN
value when it sends it to the database.For the logging, it is always
BOOLEAN
.- Specified by:
setBoolean
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setByte
Sets the designated parameter to the given Java
byte
value.The driver converts this to an SQL
TINYINT
value when it sends it to the database.- Specified by:
setByte
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setBytes
Sets the designated parameter to the given Java array of bytes.
The driver converts this to an SQL
VARBINARY
orLONGVARBINARY
(depending on the argument's size relative to the driver's limits onVARBINARY
values) when it sends it to the database.For the logging, it is always
VARBINARY
.- Specified by:
setBytes
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setCharacterStream
public final void setCharacterStream(String parameterName, Reader value, int length) throws SQLException Sets the designated parameter to the given
Reader
instance, which provides the given number of characters.When a very large UNICODE value is input to a
LONGVARCHAR
parameter, it may be more practical to send it via ajava.io.Reader
instance. The data will be read from the stream as needed until end-of-file is reached. The JDBC driver will do any necessary conversion from UNICODE to the database char format.- Specified by:
setCharacterStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the Unicode data.length
- The number of characters in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setCharacterStream
public final void setCharacterStream(String parameterName, Reader value, long length) throws SQLException Sets the designated parameter to the given
Reader
instance, which provides the given number of characters.When a very large UNICODE value is input to a
LONGVARCHAR
parameter, it may be more practical to send it via ajava.io.Reader
instance. The data will be read from the stream as needed until end-of-file is reached. The JDBC driver will do any necessary conversion from UNICODE to the database char format.- Specified by:
setCharacterStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the Unicode data.length
- The number of characters in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setCharacterStream
Sets the designated parameter to the given
Reader
instance.When a very large UNICODE value is input to a
LONGVARCHAR
parameter, it may be more practical to send it via ajava.io.Reader
instance. The data will be read from the stream as needed until end-of-file is reached. The JDBC driver will do any necessary conversion from UNICODE to the database char format.- Specified by:
setCharacterStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the Unicode data.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setClob
Sets the designated parameter to the given
Clob
instance.The driver converts this to an SQL
CLOB
value when it sends it to the database.- Specified by:
setClob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setClob
Sets the designated parameter to a
Reader
instance. The reader must contain the number of characters specified by thelength
argument, otherwise aSQLException
will be generated when theEnhancedPreparedStatement
is executed.This method differs from the
EnhancedPreparedStatement.setCharacterStream(String,Reader,int)
method because it informs the driver that the parameter value should be sent to the server as aCLOB
. When thesetCharacterStream()
method is used, the driver may have to do extra work to determine whether the parameter data should be sent to the server as aLONGVARCHAR
or aCLOB
.- Specified by:
setClob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the data to set the parameter value to.length
- The number of characters in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
, theReader
was shorter than specified, or the specified length was less than zero.
-
setCursorName
Sets the SQL cursor name to the given String, which will be used by subsequent statement
execute()
methods. This name can then be used in SQL positioned update or delete statements to identify the current row in theResultSet
instance generated by this statement. If the database does not support positioned update/delete, this method is a noop. To ensure that a cursor has the proper isolation level to support updates, the cursor'sSELECT
statement should have the formSELECT FOR UPDATE
. IfFOR UPDATE
is not present, positioned updates may fail.- Specified by:
setCursorName
in interfaceEnhancedPreparedStatement
- Parameters:
name
- The new cursor name, which must be unique within a connection.- Throws:
SQLException
- A database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setClob
Sets the designated parameter to a
Reader
instance.This method differs from the
EnhancedPreparedStatement.setCharacterStream(String,Reader,int)
method because it informs the driver that the parameter value should be sent to the server as aCLOB
. When thesetCharacterStream()
method is used, the driver may have to do extra work to determine whether the parameter data should be sent to the server as aLONGVARCHAR
or aCLOB
.- Specified by:
setClob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the data to set the parameter value to.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setDate
Sets the designated parameter to the given
Date
value using the default time zone of the virtual machine that is running the application.The driver converts this to an SQL
DATE
value when it sends it to the database.- Specified by:
setDate
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setDate
Sets the designated parameter to the given
Date
value using the givenCalendar
instance. The driver used theCalendar
instance to construct an SQLDATE
value, which the driver then sends to the database. With theCalendar
instance, the driver can calculate the date taking into account a custom timezone. If noCalendar
instance is specified, the driver uses the default timezone, which is that of the virtual machine running the application.- Specified by:
setDate
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.calendar
- TheCalendar
instance the driver will use to construct the date.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setDouble
Sets the designated parameter to the given Java
double
value.The driver converts this to an SQL
DOUBLE
value when it sends it to the database.- Specified by:
setDouble
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setFetchDirection
Gives the driver a hint as to the direction in which rows will be processed in
ResultSet
instances created using thisEnhancedPreparedStatement
object. The default value isResultSet.FETCH_FORWARD
.Note that this method sets only the default fetch direction for result sets generated by this
EnhancedPreparedStatement
instance. Each result set has its own methods for getting and setting its own fetch direction.- Specified by:
setFetchDirection
in interfaceEnhancedPreparedStatement
- Parameters:
direction
- The initial direction for processing rows.- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the given direction is not one ofResultSet.FETCH_FORWARD
,ResultSet.FETCH_REVERSE
, orResultSet.FETCH_UNKNOWN
- See Also:
-
setFetchSize
Gives the JDBC driver a hint as to the number of rows that should be fetched from the database when more rows are needed for
ResultSet
instances generated by thisEnhancedPreparedStatement
instance. If the specified value is zero, then the hint is ignored.The default value is zero.
- Specified by:
setFetchSize
in interfaceEnhancedPreparedStatement
- Parameters:
rows
- The number of rows to fetch.- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the conditionrows >= 0
was not satisfied.
-
setFloat
Sets the designated parameter to the given Java
float
value.The driver converts this to an SQL
REAL
value when it sends it to the database.- Specified by:
setFloat
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setInt
Sets the designated parameter to the given Java
int
value.The driver converts this to an SQL
INTEGER
value when it sends it to the database.- Specified by:
setInt
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setLargeMaxRows
Sets the limit for the maximum number of rows that any
ResultSet
instance generated by thisEnhancedPreparedStatement
instance can contain. If the limit is exceeded, the excess rows are silently dropped.This method should be used when the row limit may exceed
Integer.MAX_VALUE
.The default implementation will throw
UnsupportedOperationException
.- Specified by:
setLargeMaxRows
in interfaceEnhancedPreparedStatement
- Parameters:
max
- The new max rows limit; zero means there is no limit.- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the conditionmax >= 0
is not satisfied.- See Also:
-
setLong
Sets the designated parameter to the given Java
long
value.The driver converts this to an SQL
BIGINT
value when it sends it to the database.- Specified by:
setLong
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setMaxFieldSize
Sets the limit for the maximum number of bytes that can be returned for character and binary column values in a
ResultSet
object produced by thisStatement
object.This limit applies only to
JDBCType.BINARY
,JDBCType.VARBINARY
,JDBCType.LONGVARBINARY
,JDBCType.CHAR
,JDBCType.VARCHAR
,JDBCType.NCHAR
,JDBCType.NVARCHAR
,JDBCType.LONGNVARCHAR
andJDBCType.LONGVARCHAR
columns. If the limit is exceeded, the excess data is silently discarded. For maximum portability, use values greater than 256.- Specified by:
setMaxFieldSize
in interfaceEnhancedPreparedStatement
- Parameters:
max
- The new column size limit in bytes; zero means there is no limit.- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the conditionmax >= 0
is not satisfied.- See Also:
-
setMaxRows
Sets the limit for the maximum number of rows, that any
ResultSet
instance generated by thisEnhancedPreparedStatement
instance can contain, to the given number. If the limit is exceeded, the excess rows are silently dropped.- Specified by:
setMaxRows
in interfaceEnhancedPreparedStatement
- Parameters:
max
- The new max rows limit; zero means there is no limit.- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the conditionmax >= 0
was not satisfied.- See Also:
-
setNCharacterStream
public final void setNCharacterStream(String parameterName, Reader value, long length) throws SQLException Sets the designated parameter to the given
Reader
instance.The
Reader
reads the data till end-of-file is reached. The driver does the necessary conversion from Java character format to the national character set in the database.- Specified by:
setNCharacterStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the data.length
- The number of characters in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, the driver does not support national character sets, the driver detected that a data conversion error could occur, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setNCharacterStream
Sets the designated parameter to the given
Reader
instance.The
Reader
reads the data till end-of-file is reached. The driver does the necessary conversion from Java character format to the national character set in the database.- Specified by:
setNCharacterStream
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the data.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, the driver does not support national character sets, the driver detected that a data conversion error could occur, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setNClob
Sets the designated parameter to the given
NClob
value.The driver converts this to an SQL
NCLOB
value when it sends it to the database.- Specified by:
setNClob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, the driver does not support national character sets, the driver detected that a data conversion error could occur, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setNClob
Sets the designated parameter to a
Reader
instance. The reader must contain the number of characters specified by thelength
argument, otherwise aSQLException
will be generated when theEnhancedPreparedStatement
is executed.This method differs from the
EnhancedPreparedStatement.setNCharacterStream(String,Reader,long)
method because it informs the driver that the parameter value should be sent to the server as aNCLOB
. When thesetNCharacterStream()
method is used, the driver may have to do extra work to determine whether the parameter data should be sent to the server as aLONGNVARCHAR
or aNCLOB
.- Specified by:
setNClob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the data to set the parameter value to.length
- The number of characters in the stream.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
, theReader
was shorter than specified, or the specified length was less than zero.
-
setNClob
Sets the designated parameter to a
Reader
instance.This method differs from the
EnhancedPreparedStatement.setNCharacterStream(String,Reader,long)
method because it informs the driver that the parameter value should be sent to the server as aNCLOB
. When thesetNCharacterStream()
method is used, the driver may have to do extra work to determine whether the parameter data should be sent to the server as aLONGNVARCHAR
or aNCLOB
.- Specified by:
setNClob
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- Thejava.io.Reader
object that contains the data to set the parameter value to.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setNString
Sets the designated parameter to the given Java
String
value.The driver converts this to an SQL
NCHAR
,NVARCHAR
, orLONGNVARCHAR
value (depending on the argument's size relative to the driver's limits onNVARCHAR
values)when it sends it to the database.For the logging, it is always
NCHAR
.- Specified by:
setNString
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, the driver does not support national character sets, the driver detected that a data conversion error could occur, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setNull
Sets the designated parameter to SQLNULL
.- Specified by:
setNull
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.sqlType
- The SQL type code.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
setNull
Sets the designated parameter to SQL
NULL
.This version of the method
setNull()
should be used for user-defined types and REF type parameters. Examples of user-defined types include:STRUCT
,DISTINCT
,JAVA_OBJECT
, and named array types.Although this method is intended for user-defined and
REF
parameters, this method may be used to set anull
parameter of any JDBC type. If the parameter does not have a user-defined orREF
type, the giventypeName
is ignored.- Specified by:
setNull
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.sqlType
- The SQL type code.typeName
- The fully-qualified name of an SQL user-defined type; ignored if the parameter is not a user-defined type orREF
.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setObject
Sets the value of the designated parameter using the given object.
The JDBC specification specifies a standard mapping from Java
Object
types to SQL types. The given argument will be converted to the corresponding SQL type before being sent to the database.Note that this method may be used to pass database- specific abstract data types, by using a driver-specific Java type.
If the object is of a class implementing the interface
SQLData
, the JDBC driver should call the methodSQLData.writeSQL
to write it to the SQL data stream.If, on the other hand, the object is of a class implementing
Ref
,Blob
,Clob
,NClob
,Struct
,URL
,RowId
,SQLXML
orArray
, the driver should pass it to the database as a value of the corresponding SQL type.- Specified by:
setObject
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The object containing the input parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the type of the given object is ambiguous.
-
setObject
public final void setObject(String parameterName, Object value, SQLType targetSqlType, int scaleOrLength) throws SQLException Sets the value of the designated parameter using the given object.
If the second argument is an
.InputStream
or aReader
then the stream must contain the number of bytes specified by thescaleOrLength
argumentIf these conditions are not true the driver will generate a
SQLException
when the prepared statement is executed.The given Java object will be converted to the given
targetSqlType
before being sent to the database.If the object has a custom mapping (is of a class implementing the interface
SQLData
), the JDBC driver should call the methodSQLData.writeSQL(SQLOutput)
to write it to the SQL data stream.If, on the other hand, the object is of a class implementing
Ref
,Blob
,Clob
,NClob
,Struct
,URL
, orArray
, the driver should pass it to the database as a value of the corresponding SQL type.Note that this method may be used to pass database-specific abstract data types.
- Specified by:
setObject
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The object containing the input parameter value.targetSqlType
- The SQL type to be sent to the database. The scale argument may further qualify this type.scaleOrLength
- ForJDBCType.DECIMAL
orJDBCType.NUMERIC
types, this is the number of digits after the decimal point. For Java Object typesInputStream
andReader
, this is the length of the data in the stream or reader. For all other types, this value will be ignored.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the Java Object specified byvalue
is anInputStream
orReader
instance and the value of the scale parameter is less than zero.- See Also:
-
setObject
public void setObject(String parameterName, Object value, SQLType targetSqlType) throws SQLException Sets the value of the designated parameter with the given object.
This method is similar to
EnhancedPreparedStatement.setObject(String,Object,SQLType,int)
, except that it assumes a scale of zero.- Specified by:
setObject
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The object containing the input parameter value.targetSqlType
- The SQL type to be sent to the database. The scale argument may further qualify this type.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred, or this method was called on a closedEnhancedPreparedStatement
.- See Also:
-
setQueryTimeout
Sets the number of seconds the driver will wait for a
Statement
instance to execute to the given number of seconds. By default there is no limit on the amount of time allowed for a running statement to complete.If the limit is exceeded, an
SQLTimeoutException
is thrown.A JDBC driver must apply this limit to the
Statement.execute(String)
,Statement.executeQuery(String)
andStatement.executeUpdate(String)
methods.- Specified by:
setQueryTimeout
in interfaceEnhancedPreparedStatement
- Parameters:
timeout
- The new query timeout limit in seconds; zero means there is no limit- Throws:
SQLException
- A database access error occurred, this method was called on a closedEnhancedPreparedStatement
or the conditionseconds >= 0
is not satisfied- See Also:
-
setRef
Sets the designated parameter to the given
REF(<structured-type>)
value.The driver converts this to an SQL
REF
value when it sends it to the database.- Specified by:
setRef
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setRowId
Sets the designated parameter to the given
RowId
instance.The driver converts this to an SQL
ROWID
value when it sends it to the database.- Specified by:
setRowId
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setShort
Sets the designated parameter to the given Java
short
value.The driver converts this to an SQL
SMALLINT
value when it sends it to the database.- Specified by:
setShort
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setSQLXML
Sets the designated parameter to the given
SQLXML
value.The driver converts this to an SQL
SQLXML
value when it sends it to the database.- Specified by:
setSQLXML
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- AnSQLXML
instance that maps an SQLSQLXML
value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred, this method was called on a closedEnhancedPreparedStatement
, or theResult
,Writer
orOutputStream
was closed for theSQLXML
object.
-
setString
Sets the designated parameter to the given Java
String
value.The driver converts this to an SQL
VARCHAR
orLONGVARCHAR
value (depending on the argument's size relative to the driver's limits onVARCHAR
values) when it sends it to the database.For the logging, it is always
VARCHAR
.- Specified by:
setString
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setTime
Sets the designated parameter to the given
Time
value.The driver converts this to an SQL
TIME
value when it sends it to the database.- Specified by:
setTime
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setTime
Sets the designated parameter to the given
Time
value using the givenCalendar
instance. The driver used theCalendar
instance to construct an SQLTIME
value, which the driver then sends to the database. With theCalendar
instance, the driver can calculate the date taking into account a custom timezone. If noCalendar
instance is specified, the driver uses the default timezone, which is that of the virtual machine running the application.- Specified by:
setTime
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.calendar
- TheCalendar
instance the driver will use to construct the date.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setTimestamp
Sets the designated parameter to the given
Timestamp
value.The driver converts this to an SQL
TIMESTAMP
value when it sends it to the database.- Specified by:
setTimestamp
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setTimestamp
public final void setTimestamp(String parameterName, Timestamp value, Calendar calendar) throws SQLException Sets the designated parameter to the given
Timestamp
value using the givenCalendar
instance. The driver used theCalendar
instance to construct an SQLTIMESTAMP
value, which the driver then sends to the database. With theCalendar
instance, the driver can calculate the timestamp taking into account a custom timezone. If noCalendar
instance is specified, the driver uses the default timezone, which is that of the virtual machine running the application.- Specified by:
setTimestamp
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.calendar
- TheCalendar
instance the driver will use to construct the date.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-
setURL
Sets the designated parameter to the given
URL
value.The driver converts this to an SQL
DATALINK
value when it sends it to the database.- Specified by:
setURL
in interfaceEnhancedPreparedStatement
- Parameters:
parameterName
- The name of the parameter, prefixed by a colon.value
- The parameter value.- Throws:
SQLException
- The parameter name did not correspond to any defined parameter in the SQL statement, a database access error occurred or this method was called on a closedEnhancedPreparedStatement
.
-