blob: 45022b04796cd5dce0355bab36e275f353606080 (
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
|
#include "modifycommand.h"
#include "error.h"
ODBC::ModifyCommand::ModifyCommand(const ODBC::Connection & c, const std::string & sql) :
Command(c, sql)
{
}
ODBC::ModifyCommand::~ModifyCommand()
{
}
unsigned int
ODBC::ModifyCommand::execute(bool anc)
{
if (connection.txIsAborted()) {
throw Error("Transaction has been aborted, not issuing any more commands");
}
RETCODE rc = SQLExecute(hStmt);
if (rc != SQL_SUCCESS) {
if (rc == SQL_SUCCESS_WITH_INFO) {
// Log info
}
else if (rc != SQL_NO_DATA || !anc) {
connection.abortTx();
throw Error(rc, SQL_HANDLE_STMT, hStmt, "%s: SQLExecute",
__FUNCTION__);
}
}
SQLINTEGER rows;
if ((rc = SQLRowCount(hStmt, &rows)) != SQL_SUCCESS) {
connection.abortTx();
throw Error(rc, SQL_HANDLE_STMT, hStmt, "%s: SQLRowCount",
__FUNCTION__);
}
if (rows > 0 || anc) {
return rows;
}
connection.abortTx();
throw Error("%s: No rows affected", __FUNCTION__);
}
|