diff options
Diffstat (limited to 'src/server/shared/Database/Transaction.cpp')
-rw-r--r-- | src/server/shared/Database/Transaction.cpp | 69 |
1 files changed, 53 insertions, 16 deletions
diff --git a/src/server/shared/Database/Transaction.cpp b/src/server/shared/Database/Transaction.cpp index 93dc8fdc195..e45717864cf 100644 --- a/src/server/shared/Database/Transaction.cpp +++ b/src/server/shared/Database/Transaction.cpp @@ -19,9 +19,13 @@ #include "DatabaseEnv.h" #include "Transaction.h" +//- Append a raw ad-hoc query to the transaction void Transaction::Append(const char* sql) { - m_queries.push(strdup(sql)); + TransactionElementData data; + data.type = TRANSACTION_ELEMENT_RAW; + data.element.query = strdup(sql); + m_queries.push(data); } void Transaction::PAppend(const char* sql, ...) @@ -35,41 +39,74 @@ void Transaction::PAppend(const char* sql, ...) Append(szQuery); } +//- Append a prepared statement to the transaction +void Transaction::Append(PreparedStatement* stmt) +{ + TransactionElementData data; + data.type = TRANSACTION_ELEMENT_PREPARED; + data.element.stmt = stmt; + m_queries.push(data); +} + void Transaction::Cleanup() { while (!m_queries.empty()) { - free((void*)const_cast<char*>(m_queries.front())); + TransactionElementData data = m_queries.front(); + switch (data.type) + { + case TRANSACTION_ELEMENT_PREPARED: + delete data.element.stmt; + break; + case TRANSACTION_ELEMENT_RAW: + free((void*)(data.element.query)); + break; + } m_queries.pop(); } } bool TransactionTask::Execute() { - std::queue<char*>& queries = m_trans->m_queries; + std::queue<TransactionElementData> &queries = m_trans->m_queries; if (queries.empty()) return false; - const char* sql; - m_conn->BeginTransaction(); while (!queries.empty()) { - sql = queries.front(); - ASSERT(sql); - if (!m_conn->Execute(sql)) + TransactionElementData data = queries.front(); + switch (data.type) { - sLog.outSQLDriver("[Warning] Transaction aborted. %u queries not executed.", (uint32)queries.size()); - free((void*)const_cast<char*>(sql)); - queries.pop(); - m_conn->RollbackTransaction(); - return false; + case TRANSACTION_ELEMENT_PREPARED: + { + PreparedStatement* stmt = data.element.stmt; + ASSERT(stmt); + if (!m_conn->Execute(stmt)) + { + sLog.outSQLDriver("[Warning] Transaction aborted. %u queries not executed.", (uint32)queries.size()); + m_conn->RollbackTransaction(); + return false; + } + delete data.element.stmt; + } + break; + case TRANSACTION_ELEMENT_RAW: + { + const char* sql = data.element.query; + ASSERT(sql) + if (!m_conn->Execute(sql)) + { + sLog.outSQLDriver("[Warning] Transaction aborted. %u queries not executed.", (uint32)queries.size()); + m_conn->RollbackTransaction(); + return false; + } + free((void*)const_cast<char*>(sql)); + } + break; } - - free((void*)const_cast<char*>(sql)); queries.pop(); } - m_conn->CommitTransaction(); return true; } |