Commit dbc63bed authored by Sergey Petrunya's avatar Sergey Petrunya

MWL#121-125: DS-MRR improvements

- Address review feedback, step 1 
parent fae27347
...@@ -1807,6 +1807,10 @@ class handler :public Sql_alloc ...@@ -1807,6 +1807,10 @@ class handler :public Sql_alloc
inline int ha_index_first(uchar * buf); inline int ha_index_first(uchar * buf);
inline int ha_index_last(uchar * buf); inline int ha_index_last(uchar * buf);
inline int ha_index_next_same(uchar *buf, const uchar *key, uint keylen); inline int ha_index_next_same(uchar *buf, const uchar *key, uint keylen);
/*
TODO: should we make for those functions non-virtual ha_func_name wrappers,
too?
*/
virtual ha_rows multi_range_read_info_const(uint keyno, RANGE_SEQ_IF *seq, virtual ha_rows multi_range_read_info_const(uint keyno, RANGE_SEQ_IF *seq,
void *seq_init_param, void *seq_init_param,
uint n_ranges, uint *bufsz, uint n_ranges, uint *bufsz,
......
This diff is collapsed.
...@@ -61,20 +61,51 @@ class SimpleBuffer ...@@ -61,20 +61,51 @@ class SimpleBuffer
-1 <=> everthing is done from end to start instead. -1 <=> everthing is done from end to start instead.
*/ */
int direction; int direction;
/* Pointers to read data from */
uchar **write_ptr1;
size_t write_size1;
/* Same as above, but may be NULL */
uchar **write_ptr2;
size_t write_size2;
/* Pointers to write data to */
uchar **read_ptr1;
size_t read_size1;
/* Same as above, but may be NULL */
uchar **read_ptr2;
size_t read_size2;
public: public:
/* Set up writing*/
void setup_writing(uchar **data1, size_t len1,
uchar **data2, size_t len2);
void sort(qsort2_cmp cmp_func, void *cmp_func_arg);
/* Write-mode functions */ /* Write-mode functions */
void reset_for_writing(); void reset_for_writing();
void write(const uchar *data, size_t bytes); void write();
bool have_space_for(size_t bytes); bool have_space_for(size_t bytes);
private:
void write(const uchar *data, size_t bytes);
uchar *used_area() { return (direction == 1)? read_pos : write_pos; } uchar *used_area() { return (direction == 1)? read_pos : write_pos; }
size_t used_size(); size_t used_size();
public:
bool is_empty() { return used_size() == 0; } bool is_empty() { return used_size() == 0; }
/* Read-mode functions */ /* Read-mode functions */
void reset_for_reading(); void reset_for_reading();
// todo: join with setup-writing?
void setup_reading(uchar **data1, size_t len1,
uchar **data2, size_t len2);
bool read();
private:
uchar *read(size_t bytes); uchar *read(size_t bytes);
public:
bool have_data(size_t bytes); bool have_data(size_t bytes);
uchar *end_of_space(); uchar *end_of_space();
...@@ -135,7 +166,6 @@ class SimpleBuffer ...@@ -135,7 +166,6 @@ class SimpleBuffer
DBUG_ASSERT(0); /* Attempt to grow buffer in wrong direction */ DBUG_ASSERT(0); /* Attempt to grow buffer in wrong direction */
} }
//friend class PeekIterator;
class PeekIterator class PeekIterator
{ {
// if direction==1 : pointer to what to return next // if direction==1 : pointer to what to return next
...@@ -148,6 +178,26 @@ class SimpleBuffer ...@@ -148,6 +178,26 @@ class SimpleBuffer
sb= sb_arg; sb= sb_arg;
pos= sb->read_pos; pos= sb->read_pos;
} }
/*
If the buffer stores tuples, this call will return pointer to the first
component.
*/
bool read_next()
{
// Always read the first component first? (because we do inverted-writes
// if needed, so no measures need to be taken here).
uchar *res;
if ((res= get_next(sb->read_size1)))
{
*(sb->read_ptr1)= res;
if (sb->read_ptr2)
*sb->read_ptr2= get_next(sb->read_size2);
return FALSE;
}
return TRUE; /* EOF */
}
private:
/* Return pointer to next chunk of nbytes bytes and avance over it */ /* Return pointer to next chunk of nbytes bytes and avance over it */
uchar *get_next(size_t nbytes) uchar *get_next(size_t nbytes)
{ {
...@@ -170,6 +220,7 @@ class SimpleBuffer ...@@ -170,6 +220,7 @@ class SimpleBuffer
}; };
}; };
/* /*
DS-MRR implementation for one table. Create/use one object of this class for DS-MRR implementation for one table. Create/use one object of this class for
each ha_{myisam/innobase/etc} object. That object will be further referred to each ha_{myisam/innobase/etc} object. That object will be further referred to
...@@ -206,8 +257,6 @@ class SimpleBuffer ...@@ -206,8 +257,6 @@ class SimpleBuffer
scanning. scanning.
*/ */
class DsMrr_impl class DsMrr_impl
{ {
public: public:
...@@ -252,7 +301,16 @@ class DsMrr_impl ...@@ -252,7 +301,16 @@ class DsMrr_impl
/* Buffer to store rowids, or (rowid, range_id) pairs */ /* Buffer to store rowids, or (rowid, range_id) pairs */
SimpleBuffer rowid_buffer; SimpleBuffer rowid_buffer;
uchar *identical_rowid_ptr; /* Reads from rowid buffer go to here: */
uchar *rowid;
uchar *rowids_range_id;
/*
not-NULL: we're traversing a group of (rowid, range_id) pairs with
identical rowid values, and this is the pointer to the last one.
NULL: we're not in the group of indentical rowids.
*/
uchar *last_identical_rowid;
/* Identical keys */ /* Identical keys */
bool in_identical_keys_range; bool in_identical_keys_range;
......
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