ClickHouse/dbms/src/DataStreams/DistinctSortedBlockInputStream.h

68 lines
2.1 KiB
C++
Raw Normal View History

#pragma once
#include <DataStreams/IProfilingBlockInputStream.h>
#include <Interpreters/Limits.h>
#include <Interpreters/SetVariants.h>
namespace DB
{
/** This class is intended for implementation of SELECT DISTINCT clause and
* leaves only unique rows in the stream.
*
* To optimize the SELECT DISTINCT ... LIMIT clause we can
* set limit_hint to non zero value. So we stop emitting new rows after
* count of already emitted rows will reach the limit_hint.
*/
class DistinctSortedBlockInputStream : public IProfilingBlockInputStream
{
public:
/// Empty columns_ means all collumns.
DistinctSortedBlockInputStream(BlockInputStreamPtr input_, const Limits & limits, size_t limit_hint_, Names columns_);
String getName() const override { return "DistinctSorted"; }
String getID() const override;
protected:
Block readImpl() override;
private:
bool checkLimits() const;
ConstColumnPlainPtrs getKeyColumns(const Block & block) const;
/// When clearing_columns changed, we can clean HashSet to memory optimization
/// clearing_columns is a left-prefix of SortDescription exists in key_columns
ConstColumnPlainPtrs getClearingColumns(const Block & block, const ConstColumnPlainPtrs & key_columns) const;
static bool rowsEqual(const ConstColumnPlainPtrs & lhs, size_t n, const ConstColumnPlainPtrs & rhs, size_t m);
/// return true if has new data
template <typename Method>
bool buildFilter(
Method & method,
const ConstColumnPlainPtrs & key_columns,
const ConstColumnPlainPtrs & clearing_hint_columns,
IColumn::Filter & filter,
size_t rows,
ClearableSetVariants & variants) const;
const SortDescription& description;
struct PreviousBlock
{
Block block;
ConstColumnPlainPtrs clearing_hint_columns;
} prev_block;
Names columns_names;
ClearableSetVariants data;
Sizes key_sizes;
size_t limit_hint;
/// Restrictions on the maximum size of the output data.
size_t max_rows;
size_t max_bytes;
OverflowMode overflow_mode;
};
}