~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/natural_join_column.h

  • Committer: Brian Aker
  • Date: 2009-01-21 05:53:36 UTC
  • mto: This revision was merged to the branch mainline in revision 801.
  • Revision ID: brian@tangent.org-20090121055336-fxoz6wfzreo8gi9x
Removed purge

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) 2008 Sun Microsystems
 
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 DRIZZLED_NATURAL_JOIN_COLUMN_H
 
21
#define DRIZZLED_NATURAL_JOIN_COLUMN_H
 
22
 
 
23
#include <drizzled/sql_alloc.h>
 
24
 
 
25
class Field;
 
26
class TableList;
 
27
 
 
28
/*
 
29
  Column reference of a NATURAL/USING join. Since column references in
 
30
  joins can be both from views and stored tables, may point to either a
 
31
  Field (for tables).
 
32
*/
 
33
 
 
34
class Natural_join_column: public Sql_alloc
 
35
{
 
36
public:
 
37
  Field            *table_field; /* Column reference of table or temp view. */
 
38
  TableList *table_ref; /* Original base table/view reference. */
 
39
  /*
 
40
    True if a common join column of two NATURAL/USING join operands. Notice
 
41
    that when we have a hierarchy of nested NATURAL/USING joins, a column can
 
42
    be common at some level of nesting but it may not be common at higher
 
43
    levels of nesting. Thus this flag may change depending on at which level
 
44
    we are looking at some column.
 
45
  */
 
46
  bool is_common;
 
47
public:
 
48
  Natural_join_column(Field *field_param, TableList *tab);
 
49
  const char *name();
 
50
  Item *create_item(Session *session);
 
51
  Field *field();
 
52
  const char *table_name();
 
53
  const char *db_name();
 
54
};
 
55
 
 
56
 
 
57
 
 
58
#endif /* DRIZZLED_NATURAL_JOIN_COLUMN_H */