~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to client/drizzledump_drizzle.h

  • Committer: Prafulla Tekawade
  • Date: 2010-07-13 16:07:35 UTC
  • mto: (1662.1.4 rollup)
  • mto: This revision was merged to the branch mainline in revision 1664.
  • Revision ID: prafulla_t@users.sourceforge.net-20100713160735-2fsdtrm3azayuyu1
This bug is simillar to mysql bug 36133
http://bugs.mysql.com/bug.php?id=36133

Taking changes from that fix.

  - The problem was that the range optimizer evaluated constant expressions, 
    and among them it would try to evaluate IN-subquery predicates slated for
    handling with materialization strategy. However, these predicates require
    that parent_join->setup_subquery_materialization() is invoked before one
    attempts to evaluate them.
  
  - Fixed by making the range optimizer not to evaluate expressions that have
    item->is_expensive() == TRUE (these are materialization subqueries and 
    stored function calls). This should also resolve the problem that EXPLAIN 
    may be too long. 
    This change cuts off some opportunities for range optimizer, but this is 
    the price we're willing to pay for separation of query optimization and
    execution. 

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 
 *
4
 
 *  Copyright (C) 2010 Andrew Hutchings
5
 
 *
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; version 2 of the License.
9
 
 *
10
 
 *  This program is distributed in the hope that it will be useful,
11
 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 
 *  GNU General Public License for more details.
14
 
 *
15
 
 *  You should have received a copy of the GNU General Public License
16
 
 *  along with this program; if not, write to the Free Software
17
 
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
 
 */
19
 
 
20
 
#ifndef CLIENT_DRIZZLEDUMP_DRIZZLE_H
21
 
#define CLIENT_DRIZZLEDUMP_DRIZZLE_H
22
 
 
23
 
#include "drizzledump_data.h"
24
 
 
25
 
class DrizzleDumpDatabaseDrizzle;
26
 
class DrizzleDumpDataDrizzle;
27
 
 
28
 
class DrizzleDumpForeignKeyDrizzle : public DrizzleDumpForeignKey
29
 
{
30
 
  public:
31
 
    DrizzleDumpForeignKeyDrizzle(std::string name, DrizzleDumpConnection* connection) : DrizzleDumpForeignKey(name, connection)
32
 
    { }
33
 
 
34
 
    ~DrizzleDumpForeignKeyDrizzle()
35
 
    {
36
 
    }
37
 
};
38
 
 
39
 
class DrizzleDumpIndexDrizzle : public DrizzleDumpIndex
40
 
{
41
 
  public:
42
 
    DrizzleDumpIndexDrizzle(std::string &index, DrizzleDumpConnection *connection)
43
 
    : DrizzleDumpIndex(index, connection)
44
 
    { }
45
 
 
46
 
    ~DrizzleDumpIndexDrizzle()
47
 
    {
48
 
      columns.clear();
49
 
    }
50
 
};
51
 
 
52
 
class DrizzleDumpFieldDrizzle : public DrizzleDumpField
53
 
{
54
 
  public:
55
 
    DrizzleDumpFieldDrizzle(std::string &field, DrizzleDumpConnection *connection)
56
 
    : DrizzleDumpField(field, connection)
57
 
    { }
58
 
 
59
 
    ~DrizzleDumpFieldDrizzle() { }
60
 
 
61
 
    void setType(const char* raw_type, const char* collation);
62
 
};
63
 
 
64
 
class DrizzleDumpTableDrizzle : public DrizzleDumpTable
65
 
{
66
 
  public:
67
 
    DrizzleDumpTableDrizzle(std::string &table, DrizzleDumpConnection *connection)
68
 
    : DrizzleDumpTable(table, connection)
69
 
    { }
70
 
 
71
 
    ~DrizzleDumpTableDrizzle()
72
 
    {
73
 
      fields.clear();
74
 
      indexes.clear();
75
 
      fkeys.clear();
76
 
    }
77
 
    bool populateFields();
78
 
    bool populateIndexes();
79
 
    bool populateFkeys();
80
 
    DrizzleDumpData* getData(void);
81
 
};
82
 
 
83
 
class DrizzleDumpDatabaseDrizzle : public DrizzleDumpDatabase
84
 
{
85
 
  public:
86
 
    DrizzleDumpDatabaseDrizzle(const std::string &database,
87
 
      DrizzleDumpConnection *connection)
88
 
    : DrizzleDumpDatabase(database, connection)
89
 
    { }
90
 
 
91
 
    ~DrizzleDumpDatabaseDrizzle()
92
 
    {
93
 
      tables.clear();
94
 
    }
95
 
    bool populateTables(void);
96
 
    bool populateTables(const std::vector<std::string> &table_names);
97
 
    void setCollate(const char* newCollate);
98
 
 
99
 
};
100
 
 
101
 
class DrizzleDumpDataDrizzle : public DrizzleDumpData
102
 
{
103
 
  public:
104
 
    DrizzleDumpDataDrizzle(DrizzleDumpTable *dataTable,
105
 
      DrizzleDumpConnection *connection);
106
 
    ~DrizzleDumpDataDrizzle();
107
 
};
108
 
 
109
 
 
110
 
#endif /* CLIENT_DRIZZLEDUMP_DRIZZLE_H */