|  | Qore DbDataProvider Module Reference 2.1.1
    | 
Defines a data provider based on a single SQL table. More...
#include <DbTableDataProvider.qc.dox.h>
| Public Member Functions | |
| beginTransaction () | |
| Begins a transaction in the datasource underlying the table. | |
| commit () | |
| Commits data written to the data provider. | |
| constructor (*hash< auto > options) | |
| Creates the object from constructor options. | |
| constructor (AbstractTable table, *LoggerInterface logger) | |
| Creates the object. | |
| int | doSequenceCurrvalKey (string sequence_name, hash< auto > ctx, *reference< bool > missing_input) | 
| Processes the sequence_currvalruntime key in mappers as a mapper key handler. | |
| int | doSequenceKey (string sequence_name, hash< auto > ctx, *reference< bool > missing_input) | 
| Processes the sequenceruntime key in mappers as a mapper key handler. | |
| AbstractDataProviderBulkOperation | getBulkInserter () | 
| Returns a bulk insert operation object for the data provider. | |
| AbstractDataProviderBulkOperation | getBulkUpserter () | 
| Returns a bulk upsert operation object for the data provider. | |
| *AbstractDataProvider | getChildProviders () | 
| Returns child providers; return nothing if there are no child providers. | |
| *string | getDesc () | 
| Returns the data provider description. | |
| hash< DataProviderInfo > | getInfo () | 
| Returns data provider info. | |
| *hash< string, hash< MapperRuntimeKeyInfo > > | getMapperRuntimeKeys () | 
| Returns custom data mapper runtime keys. | |
| string | getName () | 
| Returns the data provider name. | |
| bool | requiresTransactionManagement () | 
| Returns True if the data provider supports transaction management. | |
| rollback () | |
| Rolls back data written to the data provider. | |
| string | upsertRecordImpl (hash< auto > rec, *hash< auto > upsert_options) | 
| Upserts the given record to the data provider. | |
| Public Attributes | |
| const | ConstructorOptions = ... | 
| Constructor options. | |
| const | CreateOptions = ... | 
| Create options; see details below. | |
| const | DbUpsertMap = ... | 
| Maps SqlUtil upsert_results to db_provider_upsert_results. | |
| const | MapperKeyInfo = ... | 
| Mapper runtime key info; see details below. | |
| const | ProviderInfo = ... | 
| Provider info. | |
| const | SearchOptions = ... | 
| Search options; see details below. | |
| const | UpsertOptions = ... | 
| Upsert options; see details below. | |
| Protected Member Functions | |
| addFieldImpl (AbstractDataField field, *hash< auto > field_add_options) | |
| Creates a new field. | |
| alignTable (hash< auto > table_desc) | |
| Align table with the given description. | |
| *hash< auto > | createRecordImpl (hash< auto > rec, *hash< auto > create_options) | 
| Writes the given record to the data provider. | |
| Mutex | db_lock () | 
| lock for "db" | |
| deleteFieldImpl (string name, *hash< auto > field_delete_options) | |
| Deletes an existing field. | |
| int | deleteRecordsImpl (*hash< auto > where_cond, *hash< auto > search_options) | 
| Deletes zero or more records. | |
| execDdlSql (list< auto > sqll) | |
| Executes the given DDL SQL string list. | |
| *hash< string, AbstractDataField > | getRecordTypeImpl (*hash< auto > search_options) | 
| Returns the description of the record type, if any. | |
| hash< DataProviderInfo > | getStaticInfoImpl () | 
| Returns data provider static info. | |
| AbstractDataProviderBulkRecordInterface | searchRecordsBulkImpl (int block_size=1000, *hash< auto > where_cond, *hash< auto > search_options) | 
| Returns an iterator for zero or more records matching the search options. | |
| DbTableRecordIterator | searchRecordsImpl (*hash< auto > where_cond, *hash< auto > search_options) | 
| Returns an iterator for zero or more records matching the search options. | |
| *hash< auto > | searchSingleRecordImpl (hash< auto > where_cond, *hash< auto > search_options) | 
| Returns a single record matching the search options. | |
| updateFieldImpl (string name, AbstractDataField field, *hash< auto > field_update_options) | |
| Updates an existing field. | |
| int | updateRecordsImpl (hash< auto > set, *hash< auto > where_cond, *hash< auto > search_options) | 
| Updates zero or more records matching the search options. | |
| bool | updateSingleRecordImpl (hash< auto > set, hash< auto > where_cond, *hash< auto > search_options) | 
| Updates a single record matching the search options. | |
| Protected Attributes | |
| AbstractDatabase | db | 
| the database object, if required | |
| AbstractTable | table | 
| the table | |
Defines a data provider based on a single SQL table.
| 
 | protected | 
Creates a new field.
| field | the field to add | 
| field_add_options | the options for adding the new field | 
| DbDataProvider::DbTableDataProvider::beginTransaction | ( | ) | 
| DbDataProvider::DbTableDataProvider::commit | ( | ) | 
Commits data written to the data provider.
| 
 | protected | 
Writes the given record to the data provider.
| rec | a hash representing a single input record | 
| create_options | the create options (see CreateOptions) after processing by validateCreateOptions() | 
| 
 | protected | 
Deletes an existing field.
| name | the name of the field to delete | 
| field_delete_options | the options for deleting the new field | 
| 
 | protected | 
Deletes zero or more records.
| where_cond | a hash for identifying the record(s) to be deleted | 
| search_options | the search options (see SearchOptions) after processing by validateSearchOptions() | 
| INVALID-OPERATION | the data provider does not support record updating | 
| AbstractDataProviderBulkOperation DbDataProvider::DbTableDataProvider::getBulkInserter | ( | ) | 
Returns a bulk insert operation object for the data provider.
| AbstractDataProviderBulkOperation DbDataProvider::DbTableDataProvider::getBulkUpserter | ( | ) | 
Returns a bulk upsert operation object for the data provider.
| *hash< string, hash< MapperRuntimeKeyInfo > > DbDataProvider::DbTableDataProvider::getMapperRuntimeKeys | ( | ) | 
Returns custom data mapper runtime keys.
| bool DbDataProvider::DbTableDataProvider::requiresTransactionManagement | ( | ) | 
Returns True if the data provider supports transaction management.
| DbDataProvider::DbTableDataProvider::rollback | ( | ) | 
Rolls back data written to the data provider.
| 
 | protected | 
Returns an iterator for zero or more records matching the search options.
| block_size | the number of records in a read block; must be a positive number | 
| where_cond | the search criteria; will be processed by processFieldValues() | 
| search_options | the search options (see SearchOptions); will be processed by validateSearchOptions() | 
| INVALID-BLOCK-SIZE | the block size must be a positive number | 
| INVALID-OPERATION | the data provider does not support reading | 
| 
 | protected | 
Returns an iterator for zero or more records matching the search options.
| where_cond | the search criteria; will be processed by processFieldValues() | 
| search_options | the search options (see SearchOptions) after processing by validateSearchOptions() | 
| 
 | protected | 
Returns a single record matching the search options.
| where_cond | the search criteria; will be processed by processFieldValues() | 
| search_options | the search options (see SearchOptions) after processing by validateSearchOptions() | 
| MULTIPLE-RECORDS-ERROR | multiple records found | 
| 
 | protected | 
Updates an existing field.
| name | the name of the current field to update | 
| field | the new definition of the field | 
| field_update_options | the options for adding the new field | 
| 
 | protected | 
Updates zero or more records matching the search options.
| set | the hash of field data to set | 
| where_cond | a hash for identifying the record(s) to be updated | 
| search_options | the search options (see SearchOptions) after processing by validateSearchOptions() | 
| 
 | protected | 
Updates a single record matching the search options.
| set | the hash of field data to set | 
| where_cond | a hash for identifying the record to be update | 
| search_options | the search options (see SearchOptions) after processing by validateSearchOptions() | 
| UPDATE-SINGLE-RECORD-ERROR | if the update would update more than one record | 
| string DbDataProvider::DbTableDataProvider::upsertRecordImpl | ( | hash< auto > | rec, | 
| *hash< auto > | upsert_options ) | 
Upserts the given record to the data provider.
| rec | a hash representing a single input record | 
| upsert_options | the upsert options (see UpsertOptions) after processing by validateUpsertOptions() | 
| const DbDataProvider::DbTableDataProvider::CreateOptions = ... | 
Create options; see details below.
The DbTableDataProvider class supports the following create option:
returning: a list having elements of one of the two following types:"key": (required) the column name to return"type": (optional) the data type for the output placeholder buffer (ex: Type::Number) | const DbDataProvider::DbTableDataProvider::MapperKeyInfo = ... | 
Mapper runtime key info; see details below.
The DbTableDataProvider class supports the following create option:
sequence: names the DB sequence that will be used to populate the fieldsequence_currval: names the DB sequence that will be used to populate the field; the current value of the sequence is used; will not increment the sequence | const DbDataProvider::DbTableDataProvider::SearchOptions = ... | 
Search options; see details below.
The DbTableDataProvider class supports the following search options:
columns: column argument for the select expression; see SqlUtil select option columns for more information on this argumentlimit: the maximum number of records to return; see SqlUtil select option limit for more information on this argumentoffset: the offset number in records to return; see SqlUtil select option offset for more information on this argumentgroupby: group by argument for the select expression; see SqlUtil select option groupby for more information on this argumenthaving: having argument for the select expression; see SqlUtil select option having for more information on this argumentorderby: order by argument for the select expression; see SqlUtil select option orderby for more information on this argumentforupdate: uses FOR UPDATE with the query to lock records selected; see SqlUtil select option forupdate for more information on this argument | const DbDataProvider::DbTableDataProvider::UpsertOptions = ... | 
Upsert options; see details below.
The DbTableDataProvider class supports the following upsert options:
upsert_strategy: an upsert strategu code; see: SqlUtil upsert strategy codes for more infoomit_update: allows for an asymmetrical upsert where a set of column values is inserted, but a smaller set is updated in case the unique key values are present in the target table; the value of this option should be set to the columns to omit in the update clause