~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/select_dumpvar.h

  • Committer: Monty Taylor
  • Date: 2011-02-13 17:26:39 UTC
  • mfrom: (2157.2.2 give-in-to-pkg-config)
  • mto: This revision was merged to the branch mainline in revision 2166.
  • Revision ID: mordred@inaugust.com-20110213172639-nhy7i72sfhoq13ms
Merged in pkg-config fixes.

Show diffs side-by-side

added added

removed removed

Lines of Context:
20
20
#ifndef DRIZZLED_SELECT_DUMPVAR_H
21
21
#define DRIZZLED_SELECT_DUMPVAR_H
22
22
 
23
 
#include <drizzled/error.h>
24
 
#include <drizzled/function/set_user_var.h>
25
 
#include <drizzled/select_result_interceptor.h>
26
 
#include <drizzled/base.h>
 
23
#include "drizzled/error.h"
 
24
#include "drizzled/function/set_user_var.h"
27
25
 
28
26
#include <vector>
29
27
 
30
28
namespace drizzled
31
29
{
32
30
 
33
 
class var;
34
 
 
35
31
class select_dumpvar :public select_result_interceptor {
36
32
  ha_rows row_count;
37
 
 
38
33
public:
39
34
  std::vector<var *> var_list;
40
35
  select_dumpvar()  { var_list.clear(); row_count= 0;}
41
36
  ~select_dumpvar() {}
42
37
 
43
 
  int prepare(List<Item> &list, Select_Lex_Unit *u);
 
38
  int prepare(List<Item> &list, Select_Lex_Unit *u)
 
39
  {
 
40
    unit= u;
 
41
 
 
42
    if (var_list.size() != list.elements)
 
43
    {
 
44
      my_message(ER_WRONG_NUMBER_OF_COLUMNS_IN_SELECT,
 
45
                 ER(ER_WRONG_NUMBER_OF_COLUMNS_IN_SELECT), MYF(0));
 
46
      return 1;
 
47
    }
 
48
    return 0;
 
49
  }
44
50
 
45
51
  void cleanup()
46
52
  {
48
54
  }
49
55
 
50
56
 
51
 
  bool send_data(List<Item> &items);
52
 
 
53
 
  bool send_eof();
 
57
  bool send_data(List<Item> &items)
 
58
  {
 
59
    
 
60
    std::vector<var *>::const_iterator iter= var_list.begin();
 
61
 
 
62
    List_iterator<Item> it(items);
 
63
    Item *item= NULL;
 
64
    var *current_var;
 
65
 
 
66
    if (unit->offset_limit_cnt)
 
67
    {                                           // using limit offset,count
 
68
      unit->offset_limit_cnt--;
 
69
      return(0);
 
70
    }
 
71
    if (row_count++)
 
72
    {
 
73
      my_message(ER_TOO_MANY_ROWS, ER(ER_TOO_MANY_ROWS), MYF(0));
 
74
      return(1);
 
75
    }
 
76
    while ((iter != var_list.end()) && (item= it++))
 
77
    {
 
78
      current_var= *iter;
 
79
      if (current_var->local == 0)
 
80
      {
 
81
        Item_func_set_user_var *suv= new Item_func_set_user_var(current_var->s, item);
 
82
        suv->fix_fields(session, 0);
 
83
        suv->check(0);
 
84
        suv->update();
 
85
      }
 
86
      ++iter;
 
87
    }
 
88
    return(session->is_error());
 
89
  }
 
90
 
 
91
  bool send_eof()
 
92
  {
 
93
    if (! row_count)
 
94
      push_warning(session, DRIZZLE_ERROR::WARN_LEVEL_WARN,
 
95
                   ER_SP_FETCH_NO_DATA, ER(ER_SP_FETCH_NO_DATA));
 
96
    /*
 
97
      In order to remember the value of affected rows for ROW_COUNT()
 
98
      function, SELECT INTO has to have an own SQLCOM.
 
99
TODO: split from SQLCOM_SELECT
 
100
  */
 
101
    session->my_ok(row_count);
 
102
    return 0;
 
103
  }
54
104
 
55
105
};
56
106