ClickHouse/dbms/src/Storages/MergeTree/MergeTreeRangeReader.h

54 lines
1.6 KiB
C++
Raw Normal View History

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 unreadRowsInCurrentGranule() const {
2017-06-15 17:01:13 +00:00
return index_granularity - read_rows_after_current_mark;
}
size_t readRowsInCurrentGranule() const { return read_rows_after_current_mark; }
size_t skipToNextMark();
MergeTreeRangeReader skipRows(size_t rows) const;
size_t read(Block & res, size_t max_rows_to_read);
bool isReadingFinished() const { return is_reading_finished; }
2017-06-15 17:01:13 +00:00
void disableNextSeek() { seek_to_from_mark = false; }
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);
2017-06-15 17:01:13 +00:00
}
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;
bool is_reading_finished;
2017-06-14 10:50:22 +00:00
friend class MergeTreeReader;
};
}