Class BatchAction
java.lang.Object
org.apache.cayenne.access.jdbc.BaseSQLAction
org.apache.cayenne.access.jdbc.BatchAction
- All Implemented Interfaces:
SQLAction
- Direct Known Subclasses:
PostgresBatchAction, SQLServerBatchAction
- Since:
- 1.2
-
Field Summary
FieldsFields inherited from class BaseSQLAction
dataNode -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected booleanprotected BatchTranslatorgetQuery()protected booleanReturns whether BatchQuery generates any keys.voidperformAction(Connection connection, OperationObserver observer) Executes a query using a strategy defined by the implementation.protected PreparedStatementprepareStatement(Connection connection, String queryStr, DbAdapter adapter, boolean generatedKeys) protected voidprocessGeneratedKeys(Statement statement, OperationObserver observer, List<BatchQueryRow> rows) protected voidprocessGeneratedKeys(Statement statement, OperationObserver observer, BatchQueryRow row) Implements generated keys extraction supported in JDBC 3.0 specification.protected voidrunAsBatch(Connection con, BatchTranslator translator, OperationObserver delegate, boolean generatesKeys) protected voidrunAsIndividualQueries(Connection connection, BatchTranslator translator, OperationObserver delegate, boolean generatesKeys) Executes batch as individual queries over the same prepared statement.protected booleansupportsGeneratedKeys(boolean isBatch) Methods inherited from class BaseSQLAction
getInMemoryOffset, readResultSetModifier and TypeMethodDescriptionprotected intgetInMemoryOffset(int queryOffset) Returns a value of the offset that will be used to rewind the ResultSet within the SQL action before reading the result rows.protected voidreadResultSet(ResultSet resultSet, RowDescriptor descriptor, Query query, OperationObserver delegate) Helper method to process a ResultSet.
-
Field Details
-
runningAsBatch
protected boolean runningAsBatch -
query
-
keyRowDescriptor
-
-
Constructor Details
-
BatchAction
- Since:
- 4.0
-
-
Method Details
-
getQuery
- Returns:
- Query which originated this action
-
performAction
-
canRunAsBatch
protected boolean canRunAsBatch() -
createTranslator
-
runAsBatch
protected void runAsBatch(Connection con, BatchTranslator translator, OperationObserver delegate, boolean generatesKeys) throws Exception - Throws:
Exception
-
runAsIndividualQueries
protected void runAsIndividualQueries(Connection connection, BatchTranslator translator, OperationObserver delegate, boolean generatesKeys) throws SQLException, Exception Executes batch as individual queries over the same prepared statement.- Throws:
SQLExceptionException
-
prepareStatement
protected PreparedStatement prepareStatement(Connection connection, String queryStr, DbAdapter adapter, boolean generatedKeys) throws SQLException - Throws:
SQLException
-
supportsGeneratedKeys
protected boolean supportsGeneratedKeys(boolean isBatch) -
hasGeneratedKeys
protected boolean hasGeneratedKeys()Returns whether BatchQuery generates any keys. -
processGeneratedKeys
protected void processGeneratedKeys(Statement statement, OperationObserver observer, BatchQueryRow row) throws SQLException Implements generated keys extraction supported in JDBC 3.0 specification.- Throws:
SQLException- Since:
- 4.0
-
processGeneratedKeys
protected void processGeneratedKeys(Statement statement, OperationObserver observer, List<BatchQueryRow> rows) throws SQLException - Throws:
SQLException- Since:
- 4.2
-