61 lines
1.3 KiB
C++
61 lines
1.3 KiB
C++
/**
|
|
* @file Transaction.cpp
|
|
* @ingroup SQLiteCpp
|
|
* @brief A Transaction is way to group multiple SQL statements into an atomic secured operation.
|
|
*
|
|
* Copyright (c) 2012-2013 Sebastien Rombauts (sebastien.rombauts@gmail.com)
|
|
*
|
|
* Distributed under the MIT License (MIT) (See accompanying file LICENSE.txt
|
|
* or copy at http://opensource.org/licenses/MIT)
|
|
*/
|
|
#include <SQLiteCpp/Transaction.h>
|
|
|
|
#include <SQLiteCpp/Database.h>
|
|
#include <SQLiteCpp/Assertion.h>
|
|
|
|
|
|
namespace SQLite
|
|
{
|
|
|
|
|
|
// Begins the SQLite transaction
|
|
Transaction::Transaction(Database& aDatabase) :
|
|
mDatabase(aDatabase),
|
|
mbCommited(false)
|
|
{
|
|
mDatabase.exec("BEGIN");
|
|
}
|
|
|
|
// Safely rollback the transaction if it has not been committed.
|
|
Transaction::~Transaction()
|
|
{
|
|
if (false == mbCommited)
|
|
{
|
|
try
|
|
{
|
|
mDatabase.exec("ROLLBACK");
|
|
}
|
|
catch (SQLite::Exception&)
|
|
{
|
|
// Never throw an exception in a destructor: error if already rollbacked, but no harm is caused by this.
|
|
}
|
|
}
|
|
}
|
|
|
|
// Commit the transaction.
|
|
void Transaction::commit()
|
|
{
|
|
if (false == mbCommited)
|
|
{
|
|
mDatabase.exec("COMMIT");
|
|
mbCommited = true;
|
|
}
|
|
else
|
|
{
|
|
throw SQLite::Exception("Transaction already commited.");
|
|
}
|
|
}
|
|
|
|
|
|
} // namespace SQLite
|