1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2009 Sun Microsystems
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; either version 2 of the License, or
9
* (at your option) any later version.
11
* This program is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
16
* You should have received a copy of the GNU General Public License
17
* along with this program; if not, write to the Free Software
18
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21
#include <drizzled/server_includes.h>
22
#include <mysys/hash.h>
23
#include <drizzled/logging.h>
24
#include <drizzled/db.h>
25
#include <drizzled/error.h>
26
#include <drizzled/nested_join.h>
27
#include <drizzled/query_id.h>
28
#include <drizzled/sql_parse.h>
29
#include <drizzled/data_home.h>
30
#include <drizzled/sql_base.h>
31
#include <drizzled/show.h>
32
#include <drizzled/info_schema.h>
33
#include <drizzled/rename.h>
34
#include <drizzled/function/time/unix_timestamp.h>
35
#include <drizzled/function/get_system_var.h>
36
#include <drizzled/item/cmpfunc.h>
37
#include <drizzled/item/null.h>
38
#include <drizzled/session.h>
39
#include <drizzled/sql_load.h>
40
#include <drizzled/connect.h>
41
#include <drizzled/lock.h>
42
#include <drizzled/select_send.h>
47
using namespace drizzled;
49
int SqlCommand::execute()
51
session->status_var.last_query_cost= 0.0;
52
int res= execute_sqlcom_select(session, all_tables);
57
int ShowStatusCommand::execute()
59
system_status_var old_status_var= session->status_var;
60
session->initial_status_var= &old_status_var;
61
int res= execute_sqlcom_select(session, all_tables);
62
/* Don't log SHOW STATUS commands to slow query log */
63
session->server_status&= ~(SERVER_QUERY_NO_INDEX_USED |
64
SERVER_QUERY_NO_GOOD_INDEX_USED);
66
* Restore status variables, as we don't want 'SHOW STATUS' to
69
pthread_mutex_lock(show_lock);
70
add_diff_to_status(&global_status_var,
73
session->status_var= old_status_var;
74
pthread_mutex_unlock(show_lock);