![]() |
Qore TableMapper Module Reference
1.3
|
maps from source to target tables with exactly the same structure More...
Public Member Methods | |
constructor (SqlUtil::Table target, hash mapv={}, *hash opts) | |
builds the object based on an optional hash providing field mappings, data constraints, and optionally custom mapping logic More... | |
constructor (SqlUtil::AbstractTable target, hash mapv={}, *hash opts) | |
builds the object based on an optional hash providing field mappings, data constraints, and optionally custom mapping logic More... | |
![]() | |
nothing | commit () |
flushes any queued data and commits the transaction | |
constructor (SqlUtil::AbstractTable target, hash mapv, *hash opts) | |
builds the object based on a hash providing field mappings, data constraints, and optionally custom mapping logic More... | |
destructor () | |
throws an exception if there is data pending in the block cache More... | |
discard () | |
discards any buffered batched data; this method should be called after using the batch APIs (queueData()) and an error occurs More... | |
*hash | flush () |
flushes any remaining batched data to the database; this method should always be called before committing the transaction or destroying the object More... | |
Qore::SQL::AbstractDatasource | getDatasource () |
returns the AbstractDatasource object associated with this object | |
*list | getReturning () |
returns a list argument for the SqlUtil "returning" option, if applicable | |
SqlUtil::AbstractTable | getTable () |
returns the underlying SqlUtil::AbstractTable object | |
string | getTableName () |
returns the table name | |
hash | insertRow (hash< auto > rec) |
inserts or upserts a row into the target table based on a mapped input record; does not commit the transaction More... | |
deprecated hash | insertRowNoCommit (hash rec) |
Plain alias to insertRow(). Obsolete. Do not use. | |
TableMapper::InboundTableMapperIterator | iterator (Qore::AbstractIterator i) |
returns an iterator for the current object More... | |
logOutput (hash h) | |
ignore logging from Mapper since we may have to log sequence values; output logged manually in insertRow() | |
hash | optionKeys () |
returns a list of valid constructor options for this class (can be overridden in subclasses) More... | |
*hash | queueData (hash< auto > rec, *hash< auto > crec) |
inserts/upserts a row (or a set of rows, in case a hash of lists is passed) into the block buffer based on a mapped input record; the block buffer is flushed to the DB if the buffer size reaches the limit defined by the "insert_block" option; does not commit the transaction More... | |
*hash | queueData (Qore::AbstractIterator iter, *hash crec) |
inserts/upserts a set of rows (from an iterator that returns hashes as values where each hash value represents an input record) into the block buffer based on a mapped input record; the block buffer is flushed to the DB if the buffer size reaches the limit defined by the "insert_block" option; does not commit the transaction More... | |
*hash | queueData (list l, *hash crec) |
inserts/upserts a set of rows (list of hashes representing input records) into the block buffer based on a mapped input record; the block buffer is flushed to the DB if the buffer size reaches the limit defined by the "insert_block" option; does not commit the transaction More... | |
nothing | rollback () |
discards any queued data and rolls back the transaction | |
setRowCode (*code rowc) | |
sets a closure or call reference 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. More... | |
hash< string, bool > | validKeys () |
returns a list of valid field keys for this class (can be overridden in subclasses) More... | |
hash< string, bool > | validTypes () |
returns a list of valid field types for this class (can be overridden in subclasses) More... | |
Static Public Member Methods | |
static hash | getStaticInputRecord (SqlUtil::AbstractTable table, *hash input) |
returns a description of the input record based on the AbstractTable source | |
![]() | |
static nothing | addBatchToBatch (reference< hash > hb, hash batch) |
static deprecated nothing | addBatchToBatch (reference< hash > hb, reference x1, hash batch, *reference x2) |
adds a batch (hash of lists) to another batch (in-place) More... | |
static hash | getOutputRecord (*string mname, AbstractTable table, *hash output) |
returns a description of the output record based on the AbstractTable target | |
Private Member Methods | |
init (hash mapv, *hash opts) | |
common constructor initialization | |
![]() | |
checkMapField (string k, reference< auto > fh) | |
perform per-field pre-processing on the passed map in the constructor More... | |
error (string fmt) | |
prepends the datasource description to the error string and calls Mapper::error() | |
error2 (string ex, string fmt) | |
prepends the datasource description to the error description and calls Mapper::error2() | |
*hash | flushIntern (bool force_flush) |
*int | getRecListSize (hash rec) |
init (hash mapv, *hash opts) | |
common constructor initialization | |
bool | isMapperConstant () |
mapFieldType (string key, hash m, reference< auto > v, hash rec) | |
performs type handling | |
*hash | queueDataIntern (hash rec) |
inserts a row into the block buffer based on a mapped input record; does not commit the transaction More... | |
hash | record2Batch (hash h) |
Additional Inherited Members | |
![]() | |
const | OptionDefaults |
default option values | |
const | OptionKeys |
option keys for this object | |
![]() | |
SqlUtil::AbstractDatabase | db |
the target Database object in case sequence value need to be acquired | |
bool | has_returning |
if the AbstractTable object supports the "returning" clause | |
hash | hbuf |
buffer for bulk DML | |
int | insert_block |
bulk DML block size (also valid for upserts despite the name) | |
list | out_args = () |
extra arguments for sequence output binds | |
list | ret_args = () |
"returning" arguments for sequences | |
Qore::SQL::AbstractSQLStatement | stmt |
statement for inserts/upserts | |
SqlUtil::AbstractTable | table |
the target table object | |
bool | unstable_input = False |
"unstable input" option for non-optimized inserts/upserts (~33% performance reduction in insert/upsert speed) | |
maps from source to target tables with exactly the same structure
TableMapper::InboundIdentityTableMapper::constructor | ( | SqlUtil::Table | target, |
hash | mapv = {} , |
||
*hash | opts | ||
) |
builds the object based on an optional hash providing field mappings, data constraints, and optionally custom mapping logic
The target table is also scanned using SqlUtil and column definitions are used to update the target record specification, also if there are any columns with NOT NULL constraints and no default value, mapping, or constant value, then a MAP-ERROR exception is thrown
target | the target table object |
mapv | a optional hash providing overrides for the default 1:1 input to output field mappings; each hash key is the name in lower case of the output column in the target table; each value is either True (meaning no translations are done; the data is copied 1:1) or a hash describing the mapping; see Mapper Specification Format for detailed documentation for this option |
opts | an optional hash of options for the mapper; see Mapper Options for a description of valid mapper options plus the following options specific to this object:
|
MAP-ERROR | the map hash has a logical error (ex: "trunc" key given without "maxlen" , invalid map key) |
TableMapper::InboundIdentityTableMapper::constructor | ( | SqlUtil::AbstractTable | target, |
hash | mapv = {} , |
||
*hash | opts | ||
) |
builds the object based on an optional hash providing field mappings, data constraints, and optionally custom mapping logic
The target table is also scanned using SqlUtil and column definitions are used to update the target record specification, also if there are any columns with NOT NULL constraints and no default value, mapping, or constant value, then a MAP-ERROR exception is thrown
target | the target table object |
mapv | a hash providing field mappings; each hash key is the name of the output field; each value is either True (meaning no translations are done; the data is copied 1:1) or a hash describing the mapping; see Mapper Specification Format for detailed documentation for this option |
opts | an optional hash of options for the mapper; see Mapper Options for a description of valid mapper options plus the following options specific to this object:
|
MAP-ERROR | the map hash has a logical error (ex: "trunc" key given without "maxlen" , invalid map key) |
TABLE-ERROR | the table includes a column using an unknown native data type |