Commit 96cf9a66 authored by unknown's avatar unknown

MWL#68 Subquery optimization: Efficient NOT IN execution with NULLs

This patch mainly adds sorting of all indexes for partial matching
according to their NULL selectivity. The patch also fixes a related bug
in subselect_rowid_merge_engine::test_null_row() where the wrong matched
indexes were skipped.

In addition the patch:
- adds few ::print() methods,
- renames few variables that had similar names but different purpose.
parent ac6b472c
This diff is collapsed.
...@@ -752,7 +752,7 @@ class Ordered_key ...@@ -752,7 +752,7 @@ class Ordered_key
Index of the key in an array of keys. This index allows to Index of the key in an array of keys. This index allows to
construct (sub)sets of keys represented by bitmaps. construct (sub)sets of keys represented by bitmaps.
*/ */
uint key_idx; uint keyid;
/* The table being indexed. */ /* The table being indexed. */
TABLE *tbl; TABLE *tbl;
/* The columns being indexed. */ /* The columns being indexed. */
...@@ -810,7 +810,7 @@ class Ordered_key ...@@ -810,7 +810,7 @@ class Ordered_key
public: public:
static void *operator new(size_t size) throw () static void *operator new(size_t size) throw ()
{ return sql_alloc(size); } { return sql_alloc(size); }
Ordered_key(uint key_idx_arg, TABLE *tbl_arg, Ordered_key(uint keyid_arg, TABLE *tbl_arg,
Item *search_key_arg, ha_rows null_count_arg, Item *search_key_arg, ha_rows null_count_arg,
ha_rows min_null_row_arg, ha_rows max_null_row_arg, ha_rows min_null_row_arg, ha_rows max_null_row_arg,
uchar *row_num_to_rowid_arg); uchar *row_num_to_rowid_arg);
...@@ -822,7 +822,7 @@ class Ordered_key ...@@ -822,7 +822,7 @@ class Ordered_key
bool init(int col_idx); bool init(int col_idx);
uint get_column_count() { return key_column_count; } uint get_column_count() { return key_column_count; }
uint get_key_idx() { return key_idx; } uint get_keyid() { return keyid; }
uint get_field_idx(uint i) uint get_field_idx(uint i)
{ {
DBUG_ASSERT(i < key_column_count); DBUG_ASSERT(i < key_column_count);
...@@ -841,8 +841,7 @@ class Ordered_key ...@@ -841,8 +841,7 @@ class Ordered_key
} }
void sort_keys(); void sort_keys();
double null_selectivity();
double null_selectivity() { return (1 - null_count / null_key.n_bits); }
/* /*
Position the current element at the first row that matches the key. Position the current element at the first row that matches the key.
...@@ -896,6 +895,7 @@ class Ordered_key ...@@ -896,6 +895,7 @@ class Ordered_key
return FALSE; return FALSE;
return bitmap_is_set(&null_key, row_num); return bitmap_is_set(&null_key, row_num);
} }
void print(String *str);
}; };
...@@ -957,10 +957,10 @@ class subselect_rowid_merge_engine: public subselect_engine ...@@ -957,10 +957,10 @@ class subselect_rowid_merge_engine: public subselect_engine
bool has_covering_null_row; bool has_covering_null_row;
protected: protected:
/* /*
Comparison function to compare keys in order of increasing bitmap Comparison function to compare keys in order of decreasing bitmap
selectivity. selectivity.
*/ */
static int cmp_keys_by_null_selectivity(Ordered_key *a, Ordered_key *b); static int cmp_keys_by_null_selectivity(Ordered_key **k1, Ordered_key **k2);
/* /*
Comparison function used by the priority queue pq, the 'smaller' key Comparison function used by the priority queue pq, the 'smaller' key
is the one with the smaller current row number. is the one with the smaller current row number.
...@@ -992,7 +992,7 @@ class subselect_rowid_merge_engine: public subselect_engine ...@@ -992,7 +992,7 @@ class subselect_rowid_merge_engine: public subselect_engine
uint8 uncacheable() { return UNCACHEABLE_DEPENDENT; } uint8 uncacheable() { return UNCACHEABLE_DEPENDENT; }
void exclude() {} void exclude() {}
table_map upper_select_const_tables() { return 0; } table_map upper_select_const_tables() { return 0; }
void print(String*, enum_query_type) {} void print(String*, enum_query_type);
bool change_result(Item_subselect*, select_result_interceptor*) bool change_result(Item_subselect*, select_result_interceptor*)
{ DBUG_ASSERT(FALSE); return false; } { DBUG_ASSERT(FALSE); return false; }
bool no_tables() { return false; } bool no_tables() { return false; }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment