Library: Data
Package: DataCore
Header: Poco/Data/AbstractSessionImpl.h
A partial implementation of SessionImpl, providing features and properties management.
To implement a certain feature or property, a subclass must provide setter and getter methods and register them with addFeature() or addProperty().
Direct Base Classes: SessionImpl
All Base Classes: SessionImpl, Poco::RefCountedObject
Member Functions: addFeature, addProperty, getBulk, getEmptyStringIsNull, getFeature, getForceEmptyString, getHandle, getProperty, getStorage, setBulk, setEmptyStringIsNull, setFeature, setForceEmptyString, setHandle, setProperty, setStorage
Inherited Functions: begin, canTransact, close, commit, connectionString, connectorName, createStatementImpl, duplicate, getConnectionTimeout, getFeature, getLoginTimeout, getProperty, getTransactionIsolation, hasTransactionIsolation, isConnected, isTransaction, isTransactionIsolation, open, reconnect, referenceCount, release, rollback, setConnectionString, setConnectionTimeout, setFeature, setLoginTimeout, setProperty, setTransactionIsolation, uri
typedef Poco::Any (C::* PropertyGetter)(const std::string &);
The getter method for a property.
typedef bool (C::* FeatureGetter)(const std::string &);
The getter method for a feature.
typedef void (C::* FeatureSetter)(const std::string &, bool);
The setter method for a feature.
typedef void (C::* PropertySetter)(const std::string &, const Poco::Any &);
The setter method for a property.
AbstractSessionImpl(
const std::string & connectionString,
std::size_t timeout = LOGIN_TIMEOUT_DEFAULT
);
Creates the AbstractSessionImpl.
Adds "storage" property and sets the default internal storage container type to std::deque. The storage is created by statements automatically whenever a query returning results is executed but external storage is provided by the user. Storage type can be reconfigured at runtime both globally (for the duration of the session) and locally (for a single statement execution only). See StatementImpl for details on how this property is used at runtime.
Adds "handle" property which, if set by the back end, returns native handle for the back end DB.
Adds "bulk" feature and sets it to false. Bulk feature determines whether the session is capable of bulk operations. Connectors that are capable of it must set this feature prior to attempting bulk operations.
Adds "emptyStringIsNull" feature and sets it to false. This feature should be set to true in order to modify the behavior of the databases that distinguish between zero-length character strings as nulls. Setting this feature to true shall disregard any difference between empty character strings and nulls, causing the framework to treat them the same (i.e. behave like Oracle).
Adds "forceEmptyString" feature and sets it to false. This feature should be set to true in order to force the databases that do not distinguish empty strings from nulls (e.g. Oracle) to always report empty string.
The "emptyStringIsNull" and "forceEmptyString" features are mutually exclusive. While these features can not both be true at the same time, they can both be false, resulting in default underlying database behavior.
Destroys the AbstractSessionImpl.
bool getBulk(
const std::string & name = ""
);
Returns the execution type
bool getEmptyStringIsNull(
const std::string & name = ""
);
Returns the setting for the behavior regarding empty variable length strings. See setEmptyStringIsNull(const std::string&, bool) and this class documentation for feature rationale and details.
bool getFeature(
const std::string & name
);
Looks a feature up in the features map and calls the feature's getter, if there is one.
See also: Poco::Data::SessionImpl::getFeature()
bool getForceEmptyString(
const std::string & name = ""
);
Returns the setting for the behavior regarding empty variable length strings. See setForceEmptyString(const std::string&, bool) and this class documentation for feature rationale and details.
Poco::Any getHandle(
const std::string & name = ""
);
Returns the native session handle.
Poco::Any getProperty(
const std::string & name
);
Looks a property up in the properties map and calls the property's getter, if there is one.
See also: Poco::Data::SessionImpl::getProperty()
Poco::Any getStorage(
const std::string & name = ""
);
Returns the storage type
void setBulk(
const std::string & name,
bool bulk
);
Sets the execution type.
void setEmptyStringIsNull(
const std::string & name,
bool emptyStringIsNull
);
Sets the behavior regarding empty variable length strings. Those are treated as NULL by Oracle and as empty string by most other databases. When this feature is true, empty strings are treated as NULL.
void setFeature(
const std::string & name,
bool state
);
Looks a feature up in the features map and calls the feature's setter, if there is one.
See also: Poco::Data::SessionImpl::setFeature()
void setForceEmptyString(
const std::string & name,
bool forceEmptyString
);
Sets the behavior regarding empty variable length strings. Those are treated as NULL by Oracle and as empty string by most other databases. When this feature is true, both empty strings and NULL values are reported as empty strings.
void setHandle(
const std::string & name,
const Poco::Any & handle
);
Sets the native session handle.
void setProperty(
const std::string & name,
const Poco::Any & value
);
Looks a property up in the properties map and calls the property's setter, if there is one.
See also: Poco::Data::SessionImpl::setProperty()
void setStorage(
const std::string & value
);
Sets the storage type.
void setStorage(
const std::string & name,
const Poco::Any & value
);
Sets the storage type.
void addFeature(
const std::string & name,
FeatureSetter setter,
FeatureGetter getter
);
Adds a feature to the map of supported features.
The setter or getter can be null, in case setting or getting a feature is not supported.
void addProperty(
const std::string & name,
PropertySetter setter,
PropertyGetter getter
);
Adds a property to the map of supported properties.
The setter or getter can be null, in case setting or getting a property is not supported.