2017-06-14 10:50:22 +00:00
|
|
|
#pragma once
|
|
|
|
#include <Core/Block.h>
|
2017-06-15 17:01:13 +00:00
|
|
|
#include <common/logger_useful.h>
|
2017-06-14 10:50:22 +00:00
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
class MergeTreeReader;
|
|
|
|
// void MergeTreeReader::readRange(size_t from_mark, bool is_first_mark_in_range, size_t max_rows_to_read, Block & res);
|
|
|
|
|
|
|
|
class MergeTreeRangeReader
|
|
|
|
{
|
|
|
|
public:
|
2017-06-15 17:01:13 +00:00
|
|
|
size_t unreadRows() const {
|
|
|
|
return (last_mark - current_mark) * index_granularity - read_rows_after_current_mark;
|
|
|
|
}
|
|
|
|
size_t unreadRowsInCurrentPart() const {
|
|
|
|
return index_granularity - read_rows_after_current_mark;
|
|
|
|
}
|
|
|
|
|
|
|
|
void skipToNextMark();
|
|
|
|
const MergeTreeRangeReader skipRows(size_t rows) const;
|
2017-06-14 10:50:22 +00:00
|
|
|
bool read(Block & res, size_t max_rows_to_read);
|
2017-06-15 17:01:13 +00:00
|
|
|
|
|
|
|
~MergeTreeRangeReader() {
|
|
|
|
if (last_mark != current_mark)
|
|
|
|
LOG_ERROR(logger, "last_mark = " << last_mark << " current_mark = " << current_mark << " read_rows_after_current_mark = " << read_rows_after_current_mark);
|
|
|
|
}
|
|
|
|
|
|
|
|
MergeTreeRangeReader copyForReader(MergeTreeReader & reader);
|
2017-06-14 10:50:22 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
MergeTreeRangeReader(MergeTreeReader & merge_tree_reader, size_t from_mark, size_t to_mark, size_t index_granularity);
|
|
|
|
|
2017-06-15 17:01:13 +00:00
|
|
|
Poco::Logger * logger;
|
|
|
|
|
2017-06-14 10:50:22 +00:00
|
|
|
std::reference_wrapper<MergeTreeReader> merge_tree_reader;
|
|
|
|
size_t current_mark;
|
|
|
|
size_t last_mark;
|
|
|
|
size_t read_rows_after_current_mark;
|
|
|
|
size_t index_granularity;
|
2017-06-15 17:01:13 +00:00
|
|
|
bool seek_to_from_mark;
|
2017-06-14 10:50:22 +00:00
|
|
|
|
|
|
|
friend class MergeTreeReader;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|