public interface StatementEventListener extends EventListener
The JDBC 3.0 specification added the maxStatements
ConnectionPooledDataSource
property to provide a standard mechanism for
enabling the pooling of PreparedStatements
and to specify the size of the statement
pool. However, there was no way for a driver to notify an external
statement pool when a PreparedStatement
becomes invalid. For some databases, a
statement becomes invalid if a DDL operation is performed that affects the
table. For example an application may create a temporary table to do some work
on the table and then destroy it. It may later recreate the same table when
it is needed again. Some databases will invalidate any prepared statements
that reference the temporary table when the table is dropped.
Similar to the methods defined in the ConnectionEventListener
interface,
the driver will call the StatementEventListener.statementErrorOccurred
method prior to throwing any exceptions when it detects a statement is invalid.
The driver will also call the StatementEventListener.statementClosed
method when a PreparedStatement
is closed.
Methods which allow a component to register a StatementEventListener with a
PooledConnection
have been added to the PooledConnection
interface.
Modifier and Type | Method and Description |
---|---|
void |
statementClosed(StatementEvent event)
The driver calls this method on all
StatementEventListener s registered on the connection when it detects that a
PreparedStatement is closed. |
void |
statementErrorOccurred(StatementEvent event)
The driver calls this method on all
StatementEventListener s
registered on the connection when it detects that a
PreparedStatement is invalid. |
void statementClosed(StatementEvent event)
StatementEventListener
s registered on the connection when it detects that a
PreparedStatement
is closed.event
- an event object describing the source of
the event and that the PreparedStatement
was closed.void statementErrorOccurred(StatementEvent event)
StatementEventListener
s
registered on the connection when it detects that a
PreparedStatement
is invalid. The driver calls this method
just before it throws the SQLException
,
contained in the given event, to the application.event
- an event object describing the source of the event,
the statement that is invalid and the exception the
driver is about to throw. The source of the event is
the PooledConnection
which the invalid PreparedStatement
is associated with. Submit a bug or feature
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 1993, 2016, Oracle and/or its affiliates. All rights reserved.
DRAFT 9-internal+0-2016-01-26-133437.ivan.openjdk9onspinwait