~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/statement/drop_table.cc

  • Committer: Padraig O'Sullivan
  • Date: 2009-09-13 00:53:34 UTC
  • mto: (1126.9.2 captain-20090915-01)
  • mto: This revision was merged to the branch mainline in revision 1133.
  • Revision ID: osullivan.padraig@gmail.com-20090913005334-6wio2sbjugskfbm3
Added calls to the connection start/end dtrace probes.

Show diffs side-by-side

added added

removed removed

Lines of Context:
18
18
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19
19
 */
20
20
 
21
 
#include "config.h"
 
21
#include <drizzled/server_includes.h>
22
22
#include <drizzled/show.h>
23
23
#include <drizzled/session.h>
24
 
#include <drizzled/lock.h>
25
24
#include <drizzled/statement/drop_table.h>
26
 
#include "drizzled/sql_table.h"
27
 
 
28
 
namespace drizzled
29
 
{
30
 
 
31
 
 
32
 
/*
33
 
 delete (drop) tables.
34
 
 
35
 
  SYNOPSIS
36
 
   mysql_rm_table()
37
 
   session                      Thread handle
38
 
   tables               List of tables to delete
39
 
   if_exists            If 1, don't give error if one table doesn't exists
40
 
 
41
 
  NOTES
42
 
    Will delete all tables that can be deleted and give a compact error
43
 
    messages for tables that could not be deleted.
44
 
    If a table is in use, we will wait for all users to free the table
45
 
    before dropping it
46
 
 
47
 
    Wait if global_read_lock (FLUSH TABLES WITH READ LOCK) is set, but
48
 
    not if under LOCK TABLES.
49
 
 
50
 
  RETURN
51
 
    false OK.  In this case ok packet is sent to user
52
 
    true  Error
53
 
 
54
 
*/
55
 
 
56
 
static bool mysql_rm_table(Session *session, TableList *tables, bool if_exists, bool drop_temporary)
57
 
{
58
 
  bool error, need_start_waiting= false;
59
 
 
60
 
  /* mark for close and remove all cached entries */
61
 
 
62
 
  if (not drop_temporary)
63
 
  {
64
 
    if (not (need_start_waiting= !wait_if_global_read_lock(session, false, true)))
65
 
      return true;
66
 
  }
67
 
 
68
 
  /*
69
 
    Acquire LOCK_open after wait_if_global_read_lock(). If we would hold
70
 
    LOCK_open during wait_if_global_read_lock(), other threads could not
71
 
    close their tables. This would make a pretty deadlock.
72
 
  */
73
 
  error= mysql_rm_table_part2(session, tables, if_exists, drop_temporary);
74
 
 
75
 
  if (need_start_waiting)
76
 
    start_waiting_global_read_lock(session);
77
 
 
78
 
  if (error)
79
 
    return true;
80
 
 
81
 
  session->my_ok();
82
 
 
83
 
  return false;
84
 
}
 
25
 
 
26
using namespace drizzled;
85
27
 
86
28
bool statement::DropTable::execute()
87
29
{
88
30
  TableList *first_table= (TableList *) session->lex->select_lex.table_list.first;
89
31
  TableList *all_tables= session->lex->query_tables;
90
32
  assert(first_table == all_tables && first_table != 0);
91
 
 
92
 
  if (not drop_temporary)
 
33
  if (! session->lex->drop_temporary)
93
34
  {
94
 
    if (not session->endActiveTransaction())
 
35
    if (! session->endActiveTransaction())
95
36
    {
96
37
      return true;
97
38
    }
98
39
  }
99
 
 
 
40
  else
 
41
  {
 
42
    /* So that DROP TEMPORARY TABLE gets to binlog at commit/rollback */
 
43
    session->options|= OPTION_KEEP_LOG;
 
44
  }
100
45
  /* DDL and binlog write order protected by LOCK_open */
101
 
  bool res= mysql_rm_table(session,
102
 
                           first_table,
103
 
                           drop_if_exists,
104
 
                           drop_temporary);
 
46
  bool res= mysql_rm_table(session, 
 
47
                           first_table, 
 
48
                           session->lex->drop_if_exists, 
 
49
                           session->lex->drop_temporary);
105
50
  return res;
106
51
}
107
 
 
108
 
} /* namespace drizzled */