Poco::Data::ODBC

class Preparator

Library: Data
Package: DataCore
Header: Poco/Data/ODBC/Preparator.h

Description

Class used for database preparation where we first have to register all data types with respective memory output locations before extracting data. Extraction works in two-phases: first prepare is called once, then extract n-times. In ODBC, SQLBindCol/SQLFetch is the preferred method of data retrieval (SQLGetData is available, however with numerous driver implementation dependent limitations and inferior performance). In order to fit this functionality into Poco DataConnectors framework, every ODBC SQL statement instantiates its own Preparator object. This is done once per statement execution (from StatementImpl::bindImpl()).

Preparator object is used to :

1) Prepare SQL statement.
2) Provide and contain the memory locations where retrieved values are placed during recordset iteration.
3) Keep count of returned number of columns with their respective datatypes and sizes.

Notes:

- Value datatypes in this interface prepare() calls serve only for the purpose of type distinction. - Preparator keeps its own std::vector<Any> buffer for fetched data to be later retrieved by Extractor. - prepare() methods should not be called when extraction mode is DE_MANUAL

Inheritance

Direct Base Classes: Poco::Data::AbstractPreparator

All Base Classes: Poco::Data::AbstractPreparator

Member Summary

Member Functions: actualDataSize, at, bulkSize, columns, getDataExtraction, getMaxFieldSize, maxDataSize, operator [], prepare, setDataExtraction, setMaxFieldSize

Inherited Functions: getLength, isBulk, prepare, setBulk, setLength

Types

CharArray

typedef std::vector < char * > CharArray;

Ptr

typedef SharedPtr < Preparator > Ptr;

Enumerations

DataExtraction

DE_MANUAL

DE_BOUND

DataType

DT_BOOL

DT_BOOL_ARRAY

DT_CHAR

DT_WCHAR

DT_UCHAR

DT_CHAR_ARRAY

DT_WCHAR_ARRAY

DT_UCHAR_ARRAY

DT_DATE

DT_TIME

DT_DATETIME

Constructors

Preparator

Preparator(
    const Preparator & other
);

Copy constructs the Preparator.

Preparator

Preparator(
    const StatementHandle & rStmt,
    const std::string & statement,
    std::size_t maxFieldSize,
    DataExtraction dataExtraction = DE_BOUND
);

Creates the Preparator.

Destructor

~Preparator virtual

~Preparator();

Destroys the Preparator.

Member Functions

actualDataSize

std::size_t actualDataSize(
    std::size_t col,
    std::size_t row = POCO_DATA_INVALID_ROW
) const;

Returns the returned length for the column and row specified. This is usually equal to the column size, except for variable length fields (BLOB and variable length strings). For null values, the return value is -1 (SQL_NO_DATA)

at inline

Poco::Any & at(
    std::size_t pos
);

Returns reference to column data.

bulkSize inline

std::size_t bulkSize(
    std::size_t col = 0
) const;

Returns bulk size. Column argument is optional since all columns must be the same size.

columns

std::size_t columns() const;

Returns the number of columns. Resizes the internal storage if and only if the size is zero.

getDataExtraction inline

DataExtraction getDataExtraction() const;

Returns data extraction mode.

getMaxFieldSize inline

std::size_t getMaxFieldSize() const;

maxDataSize

std::size_t maxDataSize(
    std::size_t pos
) const;

Returns max supported size for column at position pos. Returned length for variable length fields is the one supported by this implementation, not the underlying DB.

operator []

Poco::Any & operator[] (
    std::size_t pos
);

Returns reference to column data.

prepare virtual inline

void prepare(
    std::size_t pos,
    const Poco::Int8 & val
);

Prepares an Int8.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < Poco::Int8 > & val
);

Prepares an Int8 vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < Poco::Int8 > & val
);

Prepares an Int8 deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < Poco::Int8 > & val
);

Prepares an Int8 list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const Poco::UInt8 & val
);

Prepares an UInt8.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < Poco::UInt8 > & val
);

Prepares an UInt8 vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < Poco::UInt8 > & val
);

Prepares an UInt8 deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < Poco::UInt8 > & val
);

Prepares an UInt8 list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const Poco::Int16 & val
);

Prepares an Int16.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < Poco::Int16 > & val
);

Prepares an Int16 vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < Poco::Int16 > & val
);

Prepares an Int16 deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < Poco::Int16 > & val
);

Prepares an Int16 list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const Poco::UInt16 & val
);

Prepares an UInt16.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < Poco::UInt16 > & val
);

Prepares an UInt16 vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < Poco::UInt16 > & val
);

Prepares an UInt16 deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < Poco::UInt16 > & val
);

Prepares an UInt16 list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const Poco::Int32 & val
);

Prepares an Int32.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < Poco::Int32 > & val
);

Prepares an Int32 vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < Poco::Int32 > & val
);

Prepares an Int32 deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < Poco::Int32 > & val
);

Prepares an Int32 list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const Poco::UInt32 & val
);

Prepares an UInt32.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < Poco::UInt32 > & val
);

Prepares an UInt32 vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < Poco::UInt32 > & val
);

Prepares an UInt32 deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < Poco::UInt32 > & val
);

Prepares an UInt32 list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const Poco::Int64 & val
);

Prepares an Int64.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < Poco::Int64 > & val
);

Prepares an Int64 vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < Poco::Int64 > & val
);

Prepares an Int64 deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < Poco::Int64 > & val
);

Prepares an Int64 list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const Poco::UInt64 & val
);

Prepares an UInt64.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < Poco::UInt64 > & val
);

Prepares an UInt64 vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < Poco::UInt64 > & val
);

Prepares an UInt64 deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < Poco::UInt64 > & val
);

Prepares an UInt64 list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const bool & val
);

Prepares a boolean.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < bool > & val
);

Prepares a boolean vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < bool > & val
);

Prepares a boolean deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < bool > & val
);

Prepares a boolean list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const float & val
);

Prepares a float.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < float > & val
);

Prepares a float vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < float > & val
);

Prepares a float deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < float > & val
);

Prepares a float list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const double & val
);

Prepares a double.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < double > & val
);

Prepares a double vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < double > & val
);

Prepares a double deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < double > & val
);

Prepares a double list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const char & val
);

Prepares a single character.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < char > & val
);

Prepares a single character vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < char > & val
);

Prepares a single character deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < char > & val
);

Prepares a single character list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::string & val
);

Prepares a string.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < std::string > & val
);

Prepares a string vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < std::string > & val
);

Prepares a string deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < std::string > & val
);

Prepares a string list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const UTF16String & val
);

Prepares a string.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::vector < UTF16String > & val
);

Prepares a string vector.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::deque < UTF16String > & val
);

Prepares a string deque.

See also: Poco::Data::AbstractPreparator::prepare()

prepare virtual

void prepare(
    std::size_t pos,
    const std::list < UTF16String > & val
);

Prepares a string list.

See also: Poco::Data::AbstractPreparator::prepare()

prepare

void prepare(
    std::size_t pos,
    const Poco::Data::BLOB & val
);

Prepares a BLOB.

prepare

void prepare(
    std::size_t pos,
    const std::vector < Poco::Data::BLOB > & val
);

Prepares a BLOB vector.

prepare

void prepare(
    std::size_t pos,
    const std::deque < Poco::Data::BLOB > & val
);

Prepares a BLOB deque.

prepare

void prepare(
    std::size_t pos,
    const std::list < Poco::Data::BLOB > & val
);

Prepares a BLOB list.

prepare

void prepare(
    std::size_t pos,
    const Poco::Data::CLOB & val
);

Prepares a CLOB.

prepare

void prepare(
    std::size_t pos,
    const std::vector < Poco::Data::CLOB > & val
);

Prepares a CLOB vector.

prepare

void prepare(
    std::size_t pos,
    const std::deque < Poco::Data::CLOB > & val
);

Prepares a CLOB deque.

prepare

void prepare(
    std::size_t pos,
    const std::list < Poco::Data::CLOB > & val
);

Prepares a CLOB list.

prepare

void prepare(
    std::size_t pos,
    const Poco::Data::Date & val
);

Prepares a Date.

prepare

void prepare(
    std::size_t pos,
    const std::vector < Poco::Data::Date > & val
);

Prepares a Date vector.

prepare

void prepare(
    std::size_t pos,
    const std::deque < Poco::Data::Date > & val
);

Prepares a Date deque.

prepare

void prepare(
    std::size_t pos,
    const std::list < Poco::Data::Date > & val
);

Prepares a Date list.

prepare

void prepare(
    std::size_t pos,
    const Poco::Data::Time & val
);

Prepares a Time.

prepare

void prepare(
    std::size_t pos,
    const std::vector < Poco::Data::Time > & val
);

Prepares a Time vector.

prepare

void prepare(
    std::size_t pos,
    const std::deque < Poco::Data::Time > & val
);

Prepares a Time deque.

prepare

void prepare(
    std::size_t pos,
    const std::list < Poco::Data::Time > & val
);

Prepares a Time list.

prepare

void prepare(
    std::size_t pos,
    const Poco::DateTime & val
);

Prepares a DateTime.

prepare

void prepare(
    std::size_t pos,
    const std::vector < Poco::DateTime > & val
);

Prepares a DateTime vector.

prepare

void prepare(
    std::size_t pos,
    const std::deque < Poco::DateTime > & val
);

Prepares a DateTime deque.

prepare

void prepare(
    std::size_t pos,
    const std::list < Poco::DateTime > & val
);

Prepares a DateTime list.

prepare

void prepare(
    std::size_t pos,
    const Poco::Any & val
);

Prepares an Any.

prepare

void prepare(
    std::size_t pos,
    const std::vector < Poco::Any > & val
);

Prepares an Any vector.

prepare

void prepare(
    std::size_t pos,
    const std::deque < Poco::Any > & val
);

Prepares an Any deque.

prepare

void prepare(
    std::size_t pos,
    const std::list < Poco::Any > & val
);

Prepares an Any list.

prepare

void prepare(
    std::size_t pos,
    const Poco::DynamicAny & val
);

Prepares a DynamicAny.

prepare

void prepare(
    std::size_t pos,
    const std::vector < Poco::DynamicAny > & val
);

Prepares a DynamicAny vector.

prepare

void prepare(
    std::size_t pos,
    const std::deque < Poco::DynamicAny > & val
);

Prepares a DynamicAny deque.

prepare

void prepare(
    std::size_t pos,
    const std::list < Poco::DynamicAny > & val
);

Prepares a DynamicAny list.

setDataExtraction inline

void setDataExtraction(
    DataExtraction ext
);

Set data extraction mode.

setMaxFieldSize inline

void setMaxFieldSize(
    std::size_t size
);

Sets maximum supported field size.