Add MySQL Transaction support
This commit is contained in:
parent
1031ce7258
commit
e338319494
58
MySQLTransaction.cpp
Normal file
58
MySQLTransaction.cpp
Normal file
|
@ -0,0 +1,58 @@
|
|||
#include "MySQLTransaction.h"
|
||||
|
||||
Transaction::Transaction(MySQLConn& MySQLConnection) : conn(MySQLConnection)
|
||||
{
|
||||
_isReady=false;
|
||||
_operated=false;
|
||||
if(conn.exec("start transaction",nullptr)<0)
|
||||
{
|
||||
/// SQL execute error.
|
||||
}
|
||||
else
|
||||
{
|
||||
_isReady=true;
|
||||
}
|
||||
}
|
||||
|
||||
Transaction::~Transaction()
|
||||
{
|
||||
if(!_operated)
|
||||
{
|
||||
rollback();
|
||||
}
|
||||
}
|
||||
|
||||
int Transaction::commit()
|
||||
{
|
||||
if(_operated) return -2;
|
||||
|
||||
if(conn.exec("commit",nullptr)<0)
|
||||
{
|
||||
return -1;
|
||||
}
|
||||
else
|
||||
{
|
||||
_operated=true;
|
||||
return conn.getAffectedRows();
|
||||
}
|
||||
}
|
||||
|
||||
int Transaction::rollback()
|
||||
{
|
||||
if(_operated) return -2;
|
||||
|
||||
if(conn.exec("rollback",nullptr)<0)
|
||||
{
|
||||
return -1;
|
||||
}
|
||||
else
|
||||
{
|
||||
_operated=true;
|
||||
return conn.getAffectedRows();
|
||||
}
|
||||
}
|
||||
|
||||
bool Transaction::isReady() const
|
||||
{
|
||||
return _isReady;
|
||||
}
|
26
MySQLTransaction.h
Normal file
26
MySQLTransaction.h
Normal file
|
@ -0,0 +1,26 @@
|
|||
#include "MySQLWrapper.h"
|
||||
|
||||
class Transaction
|
||||
{
|
||||
public:
|
||||
/// Start Transaction on construct.
|
||||
Transaction(MySQLConn& MySQLConnection);
|
||||
|
||||
/// Rollback transaction on destruct. If commit() or rollback() is called, this function will not execute any sql.
|
||||
~Transaction();
|
||||
|
||||
/// NOTE: A Transaction can only call commit() or rollback() once, until it calls start commit again.
|
||||
/// Commit transaction. Equals to SQL: COMMIT
|
||||
/// ReturnValue: -1 SQL Error. -2 Operated >=0 Affected Rows
|
||||
int commit();
|
||||
/// Rollback transaction. Equals to SQL: ROLLBACK
|
||||
/// ReturnValue: -1 SQL Error. -2 Operated >=0 Affected Rows
|
||||
int rollback();
|
||||
|
||||
/// Check if a Transaction object is ready. If it is ready, then a transaction has started.
|
||||
bool isReady() const;
|
||||
private:
|
||||
MySQLConn& conn;
|
||||
bool _isReady;
|
||||
bool _operated;
|
||||
};
|
Reference in New Issue
Block a user