18
18
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
22
#include "drizzled/show.h"
23
#include "drizzled/session.h"
24
#include "drizzled/statement/savepoint.h"
25
#include "drizzled/transaction_services.h"
26
#include "drizzled/named_savepoint.h"
21
#include <drizzled/server_includes.h>
22
#include <drizzled/show.h>
23
#include <drizzled/session.h>
24
#include <drizzled/statement/savepoint.h>
26
using namespace drizzled;
36
28
bool statement::Savepoint::execute()
38
if (! (getSession()->options & (OPTION_NOT_AUTOCOMMIT | OPTION_BEGIN)))
30
if (! (session->options & (OPTION_NOT_AUTOCOMMIT | OPTION_BEGIN)))
40
/* AUTOCOMMIT is on and not in a BEGIN */
41
getSession()->my_ok();
46
* If AUTOCOMMIT is off and resource contexts are empty then we need
47
* to start a transaction. It will be empty when SAVEPOINT starts the
48
* transaction. Table affecting statements do this work in lockTables()
49
* by calling startStatement().
51
if ( (getSession()->options & OPTION_NOT_AUTOCOMMIT) &&
52
(getSession()->transaction.all.getResourceContexts().empty() == true) )
36
SAVEPOINT **sv, *newsv;
37
for (sv= &session->transaction.savepoints; *sv; sv= &(*sv)->prev)
54
if (getSession()->startTransaction() == false)
39
if (my_strnncoll(system_charset_info,
40
(unsigned char *) session->lex->ident.str,
41
session->lex->ident.length,
42
(unsigned char *) (*sv)->name,
46
if (*sv) /* old savepoint of the same name exists */
49
ha_release_savepoint(session, *sv); // it cannot fail
52
else if ((newsv= (SAVEPOINT *) alloc_root(&session->transaction.mem_root,
53
savepoint_alloc_size)) == 0)
55
my_error(ER_OUT_OF_RESOURCES, MYF(0));
58
newsv->name= strmake_root(&session->transaction.mem_root,
59
session->lex->ident.str,
60
session->lex->ident.length);
61
newsv->length= session->lex->ident.length;
61
* Look through the savepoints. If we find one with
62
* the same name, delete it.
63
if we'll get an error here, don't add new savepoint to the list.
64
we'll lose a little bit of memory in transaction mem_root, but it'll
65
be free'd when transaction ends anyway
64
TransactionServices &transaction_services= TransactionServices::singleton();
65
deque<NamedSavepoint> &savepoints= getSession()->transaction.savepoints;
66
deque<NamedSavepoint>::iterator iter;
68
for (iter= savepoints.begin();
69
iter != savepoints.end();
72
NamedSavepoint &sv= *iter;
73
const string &sv_name= sv.getName();
74
if (my_strnncoll(system_charset_info,
75
(unsigned char *) getSession()->lex->ident.str,
76
getSession()->lex->ident.length,
77
(unsigned char *) sv_name.c_str(),
81
if (iter != savepoints.end())
83
NamedSavepoint &sv= *iter;
84
(void) transaction_services.releaseSavepoint(*getSession(), sv);
85
savepoints.erase(iter);
88
NamedSavepoint newsv(getSession()->lex->ident.str, getSession()->lex->ident.length);
90
if (transaction_services.setSavepoint(*getSession(), newsv))
67
if (ha_savepoint(session, newsv))
96
savepoints.push_front(newsv);
97
getSession()->my_ok();
73
newsv->prev= session->transaction.savepoints;
74
session->transaction.savepoints= newsv;
103
} /* namespace drizzled */