|
| | BulkInsertOperation (AbstractTable target, Map< String, Object > opts) throws Throwable |
| | creates the object from the supplied arguments
|
| |
| | BulkInsertOperation (AbstractTable target) throws Throwable |
| | creates the object from the supplied arguments
|
| |
| void | setRowCode (BulkRowCallback rowc) throws Throwable |
| | sets a row callback that will be called when data has been sent to the database and all output data is available; must accept a hash argument that represents the data written to the database including any output arguments. This code will be reset once the transaction is commited.
|
| |
| void | setRowCode () throws Throwable |
| | clears the row callback called when data has been sent to the database and all output data is available
|
| |
|
| AbstractBulkOperation (QoreObject obj) throws Throwable |
| | creates a new AbstractBulkOperation object wrapping the Qore object
|
| |
| void | queueData (Map< String, Object > data) throws Throwable |
| | queues row data in the block buffer; the block buffer is flushed to the DB if the buffer size reaches the limit defined by the block_size option; does not commit the transaction
|
| |
| void | queueData (Map< String, Object >[] l) throws Throwable |
| | queues row data in the block buffer; the block buffer is flushed to the DB if the buffer size reaches the limit defined by the block_size option; does not commit the transaction
|
| |
| void | flush () throws Throwable |
| | flushes any remaining batched data to the database; this method should always be called before committing the transaction or destroying the object
|
| |
| void | discard () throws Throwable |
| | discards any buffered batched data; this method should be called before destroying the object if an error occurs
|
| |
|
void | commit () throws Throwable |
| | flushes any queued data and commits the transaction
|
| |
|
void | rollback () throws Throwable |
| | discards any queued data and rolls back the transaction
|
| |
|
String | getTableName () throws Throwable |
| | returns the table name
|
| |
|
AbstractTable | getTable () throws Throwable |
| | returns the underlying SqlUtil::AbstractTable object
|
| |
|
AbstractDatasource | getDatasource () throws Throwable |
| | returns the AbstractDatasource object associated with this object
|
| |
|
int | getRowCount () throws Throwable |
| | returns the affected row count
|
| |
Java wrapper for the Qore class for bulk DML insert operations.
This class assists with bulk inserts into a target table.
- Submitting Data
- To use this class, queue data in the form of a hash (a single row or a set of rows) or a list of rows by calling the queueData() method.
The queueData() method queues data to be written to the database; the queue is flush()ed automatically when block_size rows have been queued.
- Retrieving Data From Inserts
- It is possible to use sql_iop_funcs in the hashes submitted with queueData(); in this case the BulkInsertOperation class assumes that every row has the same operations as in the first row. Output data can then be processed by using the
rowcode option in the constructor() or by calling setRowCode().
In case sql_iop_funcs are used and a rowcode option is set, then the SQL DML query for inserts is creating using the "returning" insert option, therefore the DBI driver in this case must support this option as well.
- Flushing and Discarding Data
- Each call to flush() (whether implicit or explicit) will cause a single call to be made to the dataserver; all queued rows are sent in a single bulk DML call, which allows for efficient processing of large amounts of data.
A call to flush() must be made before committing the transaction to ensure that any remaining rows in the internal queue have been written to the database. Because the destructor() will throw an exception if any data is left in the internal queue when the object is destroyed, a call to discard() must be made prior to the destruction of the object in case of errors.
try {
for (Map<String, Object> i : data1) {
}
for (Map<String, Object> i : data2) {
}
ds.commit();
} catch (Throwable e) {
ds.rollback();
throw e;
}
void discard()
discards any buffered batched data; this method should be called before destroying the object if an e...
Definition AbstractBulkOperation.java:240
void flush()
flushes any remaining batched data to the database; this method should always be called before commit...
Definition AbstractBulkOperation.java:203
void queueData(Map< String, Object > data)
queues row data in the block buffer; the block buffer is flushed to the DB if the buffer size reaches...
Definition AbstractBulkOperation.java:129
Java wrapper for the Qore class for bulk DML insert operations.
Definition BulkInsertOperation.java:79
- Note
- Each bulk DML object must be manually flush()ed before committing or manually discard()ed before rolling back to ensure that all data is managed properly in the same transaction and to ensure that no exception is thrown in Qore destructor. See the example above for more information.
- Deprecated:
- Use dynamic imports instead:
import qoremod.BulkSqlUtil.BulkInsertOperation;