blob: 0e507bd0956c81ae778c556a51c015e742d91b80 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
#ifndef ODBC_CONNECTION_H
#define ODBC_CONNECTION_H
#include "../libdbpp/connection.h"
#include "../libdbpp/error.h"
#include "dsn.h"
#include "error.h"
#include <sql.h>
namespace ODBC {
class Connection : public DB::Connection {
public:
Connection(const DSN& d);
Connection(const std::string & str);
~Connection();
SQLHENV env;
SQLHDBC conn;
void finish() const;
int beginTx() const;
int commitTx() const;
int rollbackTx() const;
void abortTx() const;
bool txIsAborted() const;
bool inTx() const;
void ping() const;
std::string getAttrStr(SQLINTEGER) const;
SQLINTEGER getAttrInt(SQLINTEGER) const;
DB::BulkDeleteStyle bulkDeleteStyle() const;
DB::BulkUpdateStyle bulkUpdateStyle() const;
DB::SelectCommand * newSelectCommand(const std::string & sql) const;
DB::ModifyCommand * newModifyCommand(const std::string & sql) const;
private:
DB::BulkDeleteStyle thinkDelStyle;
DB::BulkUpdateStyle thinkUpdStyle;
void connectPre();
void connectPost();
mutable unsigned int txDepth;
mutable bool txAborted;
};
class ConnectionError : public DB::ConnectionError, public virtual Error {
public:
ConnectionError(RETCODE err, SQLSMALLINT handletype, SQLHANDLE handle, char const * stage);
ConnectionError(const ConnectionError &);
};
}
#endif
|