~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/plugin/query_rewrite.cc

  • Committer: Prafulla Tekawade
  • Date: 2010-07-18 03:36:32 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-20100718033632-p7q6qtgliqbhe38p
Fix for Bug 592444

There were two problems:
o. In greedy_search optimizer method, best_extension_by_limited search
   maintains join embedding(nestedness) of tables added so far, so that 
   correct(valid)  join order is selected
   These are requirements from nested outer join executioner.
   The problem was, embedding_map was not correctly updated when a table 
   is added to optimal plan outside best_extension_by_limited search, 
   by greedy_search method. We need to update join->cur_embedding_map
   correctly here so that execution plan for other tables get
   generated.
   Invoked checked_interleaving_with_nj from greedy_search on the
   best_table selected. Fixed its prototype to take only one JoinTab
   This is same as mysql 5.1 source tree.
o. The other problem was, join->cur_embedding_map was not restored correctly
   when a table is added to the optimal plan to reflect the current embedding 
   map. 
   Taken good documented method restore_prev_nj_state which restores 
   cur_embedding_map from mysql 5.1 source tree and modified it for drizzled 
   code.

Show diffs side-by-side

added added

removed removed

Lines of Context:
28
28
#include <algorithm>
29
29
#include <vector>
30
30
 
 
31
using namespace std;
 
32
 
31
33
namespace drizzled
32
34
{
33
35
 
34
36
namespace plugin
35
37
{
36
38
 
37
 
std::vector<plugin::QueryRewriter *> all_rewriters;
 
39
vector<plugin::QueryRewriter *> all_rewriters;
38
40
 
39
41
 
40
42
bool QueryRewriter::addPlugin(QueryRewriter *in_rewriter)
51
53
{
52
54
  if (in_rewriter != NULL)
53
55
  {
54
 
    all_rewriters.erase(std::find(all_rewriters.begin(),
55
 
                                  all_rewriters.end(),
56
 
                                  in_rewriter));
 
56
    all_rewriters.erase(find(all_rewriters.begin(),
 
57
                             all_rewriters.end(),
 
58
                             in_rewriter));
57
59
  }
58
60
}
59
61
 
62
64
 * This is the QueryRewriter::rewrite entry point.
63
65
 * This gets called from within the Drizzle kernel.
64
66
 */
65
 
void QueryRewriter::rewriteQuery(const std::string &schema, std::string &to_rewrite)
 
67
void QueryRewriter::rewriteQuery(const string &schema, string &to_rewrite)
66
68
{
67
 
  for (std::vector<plugin::QueryRewriter *>::iterator iter= all_rewriters.begin();
 
69
  for (vector<plugin::QueryRewriter *>::iterator iter= all_rewriters.begin();
68
70
       iter != all_rewriters.end();
69
71
       ++iter)
70
72
  {