aboutsummaryrefslogtreecommitdiff
path: root/src/server/shared/Database/Transaction.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/shared/Database/Transaction.cpp')
-rw-r--r--src/server/shared/Database/Transaction.cpp69
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;
}