|
| | Database () |
| |
| virtual | ~Database () |
| |
| virtual void | BeginTransaction (const bool readonly)=0 |
| | Starts a transaction. More...
|
| |
| void | BeginTransaction () |
| |
| virtual void | EndTransaction (const TransactionType::TRANSACTION_TYPE transactionType, const bool throwOnError)=0 |
| | Ends a transaction. More...
|
| |
| void | EndTransaction (const TransactionType::TRANSACTION_TYPE transactionType) |
| |
| virtual void | Connect (const ConnectionString &connectionString)=0 |
| | Connects using the given connection string. More...
|
| |
| virtual void | Disconnect ()=0 |
| | Disconnects and release connection resources. More...
|
| |
| virtual bool | IsConnected ()=0 |
| | Query if Database instance is connected. More...
|
| |
| virtual void | ExecuteNonQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, bool onCursor)=0 |
| | ExecuteQuery method Execute NonQuery (Insert, Update, Delete) SQL statements or stored procedures. More...
|
| |
| void | ExecuteNonQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement) |
| |
| virtual void | ExecuteNonQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, bool onCursor)=0 |
| | ExecuteQuery method Execute NonQuery (Insert, Update, Delete) SQL statements or stored procedures, cached in Database instance. More...
|
| |
| void | ExecuteNonQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement) |
| |
| virtual void | ExecuteNonQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters, bool onCursor)=0 |
| | ExecuteQuery method Execute NonQuery (Insert, Update, Delete) SQL statements or stored procedures. More...
|
| |
| void | ExecuteNonQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters) |
| |
| virtual void | ExecuteNonQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters, bool onCursor)=0 |
| | ExecuteQuery method Execute NonQuery (Insert, Update, Delete) SQL statements or stored procedures, cached in Database instance. More...
|
| |
| void | ExecuteNonQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters) |
| |
| virtual DataSet * | ExecuteQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, bool holdCursor, const unsigned int fetchRows)=0 |
| | ExecuteQuery method Execute Select SQL statements or stored procedures. More...
|
| |
| DataSet * | ExecuteQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, bool holdCursor) |
| |
| DataSet * | ExecuteQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement) |
| |
| virtual DataSet * | ExecuteQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const bool holdCursor, const unsigned int fetchRows)=0 |
| | ExecuteQuery method Execute Select SQL statements or stored procedures, cached in Database instance. More...
|
| |
| DataSet * | ExecuteQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, bool holdCursor) |
| |
| DataSet * | ExecuteQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement) |
| |
| virtual DataSet * | ExecuteQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters, bool holdCursor, const unsigned int fetchRows)=0 |
| | Execute Select SQL statements or stored procedures. More...
|
| |
| DataSet * | ExecuteQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters, bool holdCursor) |
| |
| DataSet * | ExecuteQuery (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters) |
| |
| virtual DataSet * | ExecuteQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters, const bool holdCursor, const unsigned int fetchRows)=0 |
| | Execute Select SQL statements or stored procedures. More...
|
| |
| DataSet * | ExecuteQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters, bool holdCursor) |
| |
| DataSet * | ExecuteQueryCached (const DataCommand::COMMAND_TYPE commandType, const string &stringStatement, const ParametersVector &vectorOfParameters) |
| |
| virtual void | ReleaseCursor (const bool checkConn)=0 |
| | If onCursor=true is passed to ExecuteQuery methods, a client is required to use these methods to release cursor resources. More...
|
| |
| void | ReleaseCursor () |
| |
| virtual bool | CursorHeld () const |
| | Determines if we can hold the cursor. More...
|
| |
| virtual void | RewindCursor ()=0 |
| | Rewind cursor to the first position. More...
|
| |
| int | getLastNumberofAffectedRows () const |
| |
Main database functional class.
Its purpose is to provide a common interface to operate over different database specific APIs. Database usage consists on making the following sequenced calls to Database class methods
- First a new Database instace is obtained from factory,
- Then, the client can easily connect to database storage by calling the Connect() method. The connection can be tested any time during the instace lifecycle using isConnected() method
- If database connection is up the client needs to spawn a new database transaction by calling BeginTransaction(readonly) method
- Transactions comprise one ore more calls to "ExecuteQuery" methods. Every database query is mapped to a Command instance and can be cached in m_StatementCache member of Database instance
- A transaction ends when the client calls EndTransaction(transactionType) performing commit or rollback on the current transaction
- The database connection is released when Disconect()
Database declare two types of "ExecuteQuery" methods
- ExecuteQuery - Create a DataCommand from passed parameters and execute it
- ExecuteQueryChached - Additionally, attempts to retrieve the params and resultset columns from DataCommand cache or adds them if not available
Database, define four library specific exception types to be used by its implementations