~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/statement/flush.cc

  • Committer: Olaf van der Spek
  • Date: 2011-04-20 09:27:49 UTC
  • mto: This revision was merged to the branch mainline in revision 2285.
  • Revision ID: olafvdspek@gmail.com-20110420092749-hw1q9rfj1pumc2no
Session Cache

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
3
 *
4
 
 *  Copyright (C) 2009 Sun Microsystems
 
4
 *  Copyright (C) 2009 Sun Microsystems, Inc.
5
5
 *
6
6
 *  This program is free software; you can redistribute it and/or modify
7
7
 *  it under the terms of the GNU General Public License as published by
18
18
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19
19
 */
20
20
 
21
 
#include "config.h"
 
21
#include <config.h>
 
22
 
22
23
#include <drizzled/show.h>
23
24
#include <drizzled/session.h>
24
25
#include <drizzled/lock.h>
25
26
#include <drizzled/statement/flush.h>
26
 
#include "drizzled/sql_table.h"
27
 
#include "drizzled/plugin/logging.h"
 
27
#include <drizzled/sql_table.h>
 
28
#include <drizzled/plugin/logging.h>
 
29
#include <drizzled/plugin/storage_engine.h>
 
30
#include <drizzled/statistics_variables.h>
28
31
 
29
 
namespace drizzled
30
 
{
 
32
namespace drizzled {
31
33
 
32
34
bool statement::Flush::execute()
33
35
{
37
39
   */
38
40
  if (not reloadCache())
39
41
  {
40
 
    /*
41
 
     * We WANT to write and we CAN write.
42
 
     * ! we write after unlocking the table.
43
 
     *
44
 
     * Presumably, RESET and binlog writing doesn't require synchronization
45
 
     */
46
 
    write_bin_log(session, *session->getQueryString());
47
 
    session->my_ok();
 
42
    session().my_ok();
48
43
  }
49
44
 
50
45
  return false;
53
48
bool statement::Flush::reloadCache()
54
49
{
55
50
  bool result= false;
56
 
  TableList *tables= (TableList *) session->lex->select_lex.table_list.first;
 
51
  TableList *tables= (TableList *) lex().select_lex.table_list.first;
57
52
 
58
53
  if (flush_log)
59
54
  {
68
63
  */
69
64
  if (flush_tables || flush_tables_with_read_lock)
70
65
  {
71
 
    if (session && flush_tables_with_read_lock)
 
66
    if (&session() && flush_tables_with_read_lock)
72
67
    {
73
 
      if (session->lockGlobalReadLock())
 
68
      if (session().lockGlobalReadLock())
74
69
      {
75
70
        return true; /* Killed */
76
71
      }
77
 
      result= session->close_cached_tables(tables, true, true);
 
72
      result= session().close_cached_tables(tables, true, true);
78
73
 
79
 
      if (session->makeGlobalReadLockBlockCommit()) /* Killed */
 
74
      if (session().makeGlobalReadLockBlockCommit()) /* Killed */
80
75
      {
81
76
        /* Don't leave things in a half-locked state */
82
 
        session->unlockGlobalReadLock();
 
77
        session().unlockGlobalReadLock();
83
78
        return true;
84
79
      }
85
80
    }
86
81
    else
87
82
    {
88
 
      result= session->close_cached_tables(tables, true, false);
 
83
      result= session().close_cached_tables(tables, true, false);
89
84
    }
90
85
  }
91
86
 
92
 
  if (session && flush_status)
 
87
  if (&session() && flush_status)
93
88
  {
94
 
    session->refresh_status();
 
89
    session().refresh_status();
95
90
  }
96
91
 
97
 
  if (session && flush_global_status)
 
92
  if (&session() && flush_global_status)
98
93
  {
99
94
    memset(&current_global_counters, 0, sizeof(current_global_counters));
100
 
    plugin::Logging::resetStats(session);
101
 
    session->refresh_status();
 
95
    plugin::Logging::resetStats(&session());
 
96
    session().refresh_status();
102
97
  }
103
98
 
104
99
  return result;