mySQL 5.0.11 sources for tomato
[tomato.git] / release / src / router / mysql / sql / sql_do.cc
blob0378daa567e7e8cf19761ddd72dfe4735380db49
1 /* Copyright (c) 2000-2006, 2008 MySQL AB
3 This program is free software; you can redistribute it and/or modify
4 it under the terms of the GNU General Public License as published by
5 the Free Software Foundation; version 2 of the License.
7 This program is distributed in the hope that it will be useful,
8 but WITHOUT ANY WARRANTY; without even the implied warranty of
9 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 GNU General Public License for more details.
12 You should have received a copy of the GNU General Public License
13 along with this program; if not, write to the Free Software
14 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */
17 /* Execute DO statement */
19 #include "mysql_priv.h"
21 bool mysql_do(THD *thd, List<Item> &values)
23 List_iterator<Item> li(values);
24 Item *value;
25 DBUG_ENTER("mysql_do");
26 if (setup_fields(thd, 0, values, MARK_COLUMNS_NONE, 0, 0))
27 DBUG_RETURN(TRUE);
28 while ((value = li++))
29 value->val_int();
30 free_underlaid_joins(thd, &thd->lex->select_lex);
32 if (thd->is_error())
35 Rollback the effect of the statement, since next instruction
36 will clear the error and the rollback in the end of
37 dispatch_command() won't work.
39 ha_autocommit_or_rollback(thd, thd->is_error());
40 thd->clear_error(); // DO always is OK
42 my_ok(thd);
43 DBUG_RETURN(FALSE);