aboutsummaryrefslogtreecommitdiff
path: root/src/server/shared/Database/SQLOperation.cpp
diff options
context:
space:
mode:
authorMachiavelli <none@none>2010-08-21 03:19:25 +0200
committerMachiavelli <none@none>2010-08-21 03:19:25 +0200
commit994186f2672547761392c71ed15ded2a83e8c20d (patch)
tree53eec0c7571642b9490d2a664671cb216a730993 /src/server/shared/Database/SQLOperation.cpp
parenta7498d2f560e24b2ae3b4f6cc46ea2223a41e16f (diff)
DB Layer:
- Make SQL Transactions actual objects used in code. (Thanks to Derex for the idea) * Uncommitted transactions will be automatically rolled back and cleaned up using ACE_Refcounted_Auto_Ptr, so no need to call Rollback() in the code. * Prevents recursive transactions and makes developers aware of transactions going on. * Gets rid of unneccesary overhead iterating over a concurrent map. - Some cleanups in affected code, including better usage of transaction control in AH / mail related code to prevent data loss. *** Experimental, use at own risk, recommended to backup your DBs. *** --HG-- branch : trunk
Diffstat (limited to 'src/server/shared/Database/SQLOperation.cpp')
-rw-r--r--src/server/shared/Database/SQLOperation.cpp49
1 files changed, 1 insertions, 48 deletions
diff --git a/src/server/shared/Database/SQLOperation.cpp b/src/server/shared/Database/SQLOperation.cpp
index 1cd45a4c0b6..a3eda4b7239 100644
--- a/src/server/shared/Database/SQLOperation.cpp
+++ b/src/server/shared/Database/SQLOperation.cpp
@@ -16,9 +16,9 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
-#include "DatabaseEnv.h"
#include "SQLOperation.h"
#include "MySQLConnection.h"
+#include "Log.h"
/*! Basic, ad-hoc queries. */
BasicStatementTask::BasicStatementTask(const char* sql) :
@@ -53,53 +53,6 @@ bool BasicStatementTask::Execute()
return m_conn->Execute(m_sql);
}
-/*! Transactions. */
-TransactionTask::TransactionTask()
-{
-}
-
-TransactionTask::~TransactionTask()
-{
-
-}
-
-void TransactionTask::ForcefulDelete()
-{
- while (!m_queries.empty())
- {
- free((void*)const_cast<char*>(m_queries.front()));
- m_queries.pop();
- }
-}
-
-bool TransactionTask::Execute()
-{
- if (m_queries.empty())
- return false;
-
- const char* sql;
-
- m_conn->BeginTransaction();
- while (!m_queries.empty())
- {
- sql = m_queries.front();
- if (!m_conn->Execute(sql))
- {
- free((void*)const_cast<char*>(sql));
- m_queries.pop();
- m_conn->RollbackTransaction();
- ForcefulDelete();
- return false;
- }
-
- free((void*)const_cast<char*>(sql));
- m_queries.pop();
- }
-
- m_conn->CommitTransaction();
- return true;
-}
-
bool SQLQueryHolder::SetQuery(size_t index, const char *sql)
{
if (m_queries.size() <= index)